原实例和新实例环境相同,均为Windows Server 2008 Cluster加SQL Server 2008 SP1。

这次做的是将旧实例的数据迁移至新实例。

一、新的SQLServer实例安装

安装的是SQL Server 2008 SP1,RTM合并SP1步骤如下:

1.将SQL Server 2008 RTM安装介质拷贝到c:\SQLServer2008_FullSP1;

2.下载SP1补丁文件,并解压到c:\SQLServer2008_FullSP1\PCU:

SQLServer2008SP1-KB968369-x64-ENU.exe

/x:c:\SQLServer2008_FullSP1\PCU

3.将setup.exe和setup.rll文件copy出来并覆盖原有的介质

robocopy C:\SQLServer2008_FullSP1\PCU

c:\SQLServer2008_FullSP1 Setup.exe

robocopy C:\SQLServer2008_FullSP1\PCU

c:\SQLServer2008_FullSP1 Setup.rll

4.将x64文件夹里的所有文件除了Microsoft.SQL.Chainer.PackageData.dll,copy覆盖到原有安装介质相应位置,可通过下面代码实现:

robocopy C:\SQLServer2008_FullSP1\pcu\x64

C:\SQLServer2008_FullSP1\x64 /XF Microsoft.SQL.Chainer.PackageData.dll

如果没有排除此dll文件,在打开setup.exe的时候会有如下报错:

The specified action LandingPage is not

supported for the SQL Server patching operation.

Error code 0x84BF0007

可用老版本恢复回去再运行。

5.如果在x64目录下有Defaultsetup.ini文件,需要在最后加上一行PCUSOURCE=".\PCU",例如:

;SQLSERVER2008 Configuration File

[SQLSERVER2008]

...

PCUSOURCE=".\PCU"

如没有此文件,创建该文件,并写入如下内容:

;SQLSERVER2008 Configuration File

[SQLSERVER2008]

PCUSOURCE=".\PCU"

Windows Cluster下安装实例和加节点命令:

Setup /SkipRules=Cluster_VerifyForErrors /Action=InstallFailoverCluster

Setup /SkipRules=Cluster_VerifyForErrors

/Action=AddNode

二、迁移login

原实例上执行以下脚本,导出login信息:

USE master

GO

IF OBJECT_ID ('sp_hexadecimal')

IS NOT NULL

DROP PROCEDURE sp_hexadecimal

GO

CREATE PROCEDURE sp_hexadecimal

@binvalue varbinary(256),

@hexvalue varchar (514) OUTPUT

AS

DECLARE @charvalue varchar

(514)

DECLARE @i int

DECLARE @length int

DECLARE @hexstring char(16)

SELECT @charvalue = '0x'

SELECT @i = 1

SELECT @length = DATALENGTH

(@binvalue)

SELECT @hexstring = '0123456789ABCDEF'

WHILE (@i <= @length)

BEGIN

DECLARE @tempint int

DECLARE @firstint int

DECLARE @secondint int

SELECT @tempint = CONVERT(int,

SUBSTRING(@binvalue,@i,1))

SELECT @firstint = FLOOR(@tempint/16)

SELECT @secondint = @tempint - (@firstint*16)

SELECT @charvalue = @charvalue +

SUBSTRING(@hexstring, @firstint+1, 1) +

SUBSTRING(@hexstring, @secondint+1, 1)

SELECT @i = @i + 1

END

SELECT @hexvalue = @charvalue

GO

IF OBJECT_ID

('sp_help_revlogin') IS NOT NULL

DROP PROCEDURE sp_help_revlogin

GO

CREATE PROCEDURE

sp_help_revlogin @login_name sysname = NULL AS

DECLARE @name sysname

DECLARE @type varchar (1)

DECLARE @hasaccess int

DECLARE @denylogin int

DECLARE @is_disabled int

DECLARE @PWD_varbinaryvarbinary (256)

DECLARE @PWD_stringvarchar (514)

DECLARE @SID_varbinary

varbinary (85)

DECLARE @SID_string varchar

(514)

DECLARE @tmpstrvarchar (1024)

DECLARE @is_policy_checked

varchar (3)

DECLARE @is_expiration_checked

varchar (3)

DECLARE @defaultdb sysname

IF (@login_name IS NULL)

DECLARE login_curs CURSOR FOR

SELECT p.sid, p.name, p.type,

p.is_disabled, p.default_database_name, l.hasaccess, l.denylogin FROM

sys.server_principals p LEFT

JOIN sys.syslogins l

ON ( l.name = p.name ) WHERE p.type IN (

'S', 'G', 'U' ) AND p.name <> 'sa'

ELSE

DECLARE login_curs CURSOR FOR

SELECT p.sid, p.name, p.type,

p.is_disabled, p.default_database_name, l.hasaccess, l.denylogin FROM

sys.server_principals p LEFT

JOIN sys.syslogins l

ON ( l.name = p.name ) WHERE p.type IN (

'S', 'G', 'U' ) AND p.name = @login_name

OPEN login_curs

FETCH NEXT FROM login_curs INTO

@SID_varbinary, @name, @type, @is_disabled, @defaultdb, @hasaccess, @denylogin

IF (@@fetch_status = -1)

BEGIN

PRINT 'No login(s) found.'

CLOSE login_curs

DEALLOCATE login_curs

RETURN -1

END

SET @tmpstr = '/*

sp_help_revlogin script. '

PRINT @tmpstr

SET @tmpstr = '** Generated ' +

CONVERT (varchar, GETDATE()) + ' on ' + @@SERVERNAME + ' */'

PRINT @tmpstr

PRINT ''

WHILE (@@fetch_status <>

-1)

BEGIN

IF (@@fetch_status <> -2)

BEGIN

PRINT ''

SET @tmpstr = '-- Login: ' + @name

PRINT @tmpstr

IF (@type IN ( 'G', 'U'))

BEGIN -- NT authenticated account/group

SET @tmpstr = 'CREATE LOGIN ' +

QUOTENAME( @name ) + ' FROM WINDOWS WITH DEFAULT_DATABASE = [' + @defaultdb +

']'

END

ELSE BEGIN -- SQL Server authentication

-- obtain password and sid

SET @PWD_varbinary = CAST(

LOGINPROPERTY( @name, 'PasswordHash' ) AS varbinary (256) )

EXEC sp_hexadecimal @PWD_varbinary,

@PWD_string OUT

EXEC sp_hexadecimal

@SID_varbinary,@SID_string OUT

-- obtain password policy state

SELECT @is_policy_checked = CASE

is_policy_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM

sys.sql_logins WHERE name = @name

SELECT @is_expiration_checked = CASE

is_expiration_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM

sys.sql_logins WHERE name = @name

SET @tmpstr = 'CREATE LOGIN ' +

QUOTENAME( @name ) + ' WITH PASSWORD = ' + @PWD_string + ' HASHED, SID = ' +

@SID_string + ', DEFAULT_DATABASE = [' + @defaultdb + ']'

IF ( @is_policy_checked IS NOT NULL )

BEGIN

SET @tmpstr = @tmpstr + ',

CHECK_POLICY = ' + @is_policy_checked

END

IF ( @is_expiration_checked IS NOT NULL

)

BEGIN

SET @tmpstr = @tmpstr + ',

CHECK_EXPIRATION = ' + @is_expiration_checked

END

END

IF (@denylogin = 1)

BEGIN -- login is denied access

SET @tmpstr = @tmpstr + '; DENY CONNECT

SQL TO ' + QUOTENAME( @name )

END

ELSE IF (@hasaccess = 0)

BEGIN -- login exists but does not have

access

SET

@tmpstr = @tmpstr + '; REVOKE CONNECT SQL TO ' + QUOTENAME( @name )

END

IF (@is_disabled = 1)

BEGIN -- login is disabled

SET @tmpstr = @tmpstr + '; ALTER LOGIN '

+ QUOTENAME( @name ) + ' DISABLE'

END

PRINT @tmpstr

END

FETCH NEXT FROM login_curs INTO

@SID_varbinary, @name, @type, @is_disabled, @defaultdb, @hasaccess, @denylogin

END

CLOSE login_curs

DEALLOCATE login_curs

RETURN 0

GO

导出login信息:

EXEC sp_help_revlogin;

三、导出Server Role信息

SELECTr.name AS SERVER_roles

,

p.name AS [Login_Name]

FROMsys.server_principals r

INNER JOIN

sys.server_role_members m

ONr.principal_id = m.role_principal_id

INNER JOIN

sys.server_principals p

ONp.principal_id = m.member_principal_id

WHERE(r.type = 'R')

ORDER BY server_roles ASC

新实例上增加Server Role步骤:

方法1:打开SQL Server

Management Studio -> Security -> Logins

双击登录用户-> Server

Roles ->勾选角色-> OK

方法2:打开SQL Server

Management Studio -> Security -> Server Roles

双击角色-> General

-> Add

添加登录用户信息,可使用Check

Names验证输入是否正确-> OK

四、恢复数据库

backup database

to

disk = 'I:\database_1.bak',

disk = 'I:\database_2.bak',

disk = 'I:\database_3.bak',

disk = 'I:\database_4.bak'

with compression , stats=5

go

恢复后,一般还会有些个性化参数需要调整,比如数据库内存等,这个可根据实际情况设置调整。

linux sql server 迁移,SQL Server2008 实例数据迁移步骤相关推荐

  1. 轻松实现SQL Server与Access、Excel数据表间的导入导出

    在SQL SERVER 2000/2005中除了使用DTS进行数据的导入导出,我们也可以使用Transact-SQL语句进行导入导出操作.在Transact-SQL语句中,我们主要使用OpenData ...

  2. SQL SERVER 和ACCESS/excel的数据导入导出

    SQL SERVER 和ACCESS/excel的数据导入导出 常规的数据导入导出: 使用DTS向导迁移你的Access数据到SQL Server,你可以使用这些步骤: 1)在SQL SERVER企业 ...

  3. 从Sql server 2000 到 Oracle 10g数据库迁移数据类型转化

    2010-01-12 从Sql server 2000 到 Oracle 10g数据库迁移数据类型转化 文章分类:数据库 SqlServer 2k转换为Oracle 10g 列名 SqlServer数 ...

  4. SQL SERVER 系列(7)数据表排序和聚集函数

    SQL SERVER 系列(6)数据表排序和聚集函数 数据表排序: 当我们在对数据库操作的时候,我们经常会遇到对年龄,对考试成绩进行排序的问题,排序可以使我们对所要显示的数据一目了然,因此排序就成为了 ...

  5. SQL Server 2008处理隐式数据类型转换在执行计划中的增强

    关注我们获得更多内容 作者 | 邹建,资深数据库专家,精通各项 SQL Server 技术,具有丰富的管理.维护.优化能力以及业务应用经验.他一直热心于技术知识的分享.传播,持续活跃在 CSDN 和 ...

  6. 如何使用SQL Server链接服务器查询Excel数据

    Linked servers allow SQL Server access to data from a remote data source. A remote data source can b ...

  7. SQL Server 默认和命名实例连接问题-TCP/IP 端口

    TCP/IP的基本工作原理这里就不浪费口水了.现在这网络年代,谁不知道TCP/IP啊.不要跟我抬杠说你偏就没听说过TCP/IP阿,真是这样那你得自己去补补课了. TCP/IP协议有两个基本的东西,一个 ...

  8. 检测java是否连接到SQL server数据库 + SQL server数据库内置账户sa无法登录

    检测java是否连接到SQL server数据库 + SQL server数据库内置账户sa无法登录 SQL 检测java是否连接到SQL server数据库 SQL server数据库内置账户SA登 ...

  9. Sql Server函数全解三数据类型转换函数和文本图像函数

    原文:Sql Server函数全解<三>数据类型转换函数和文本图像函数 一:数据类型转换函数 在同时处理不同数据类型的值时,SQL Server一般会自动进行隐士类型转换.对于数据类型相近 ...

  10. 清空SQL Server数据库中所有表数据的方法(转)

    清空SQL Server数据库中所有表数据的方法 其实删除数据库中数据的方法并不复杂,为什么我还要多此一举呢,一是我这里介绍的是删除数据库的所有数据,因为数据之间可能形成相互约束关系,删除操作可能陷入 ...

最新文章

  1. 堆排序 海量数据求前N大的值
  2. 计网 --- 域名服务系统:因特网的目录服务
  3. 【GIS导论】实验七 地图设计与输出
  4. 设计一些自学软件的小测试demo吧。
  5. educoder平台哪里有答案_GRE机经哪里找?如何获取准确的GRE机经资料
  6. printer: PJL
  7. 分享一下“rmvb转avi“的操作技巧,3步搞定
  8. python 基础-----list查找重复值
  9. 计算机基础——Word 2010
  10. 计算机竞赛制作机器人,电脑制作活动机器人项目详细说明
  11. 分享到微信微博QQ空间JS代码大全
  12. TBS1287 1/4 扫 48 通道 LED 背光驱动芯片
  13. 手机H5如何对接支付宝登陆授权以及支付(H5网站支付)
  14. python卡方拟合性检验_卡方检验
  15. 华三交换机怎么样?H3C交换机产品系列介绍!
  16. php微信支付mch_id参数格式错误,再说一下微信支付踩到的坑 mch_id 参数格式错误...
  17. linux下读取ntfs数据,在Linux中读取NTFS分区上的数据
  18. mysql excel 数据处理_将excel的数据进行sql处理
  19. “该微信号已经绑定了50个小程序,不可继续绑定”,如何自助解绑
  20. AMA(Ask Me Anything)新型问答社区模式研究

热门文章

  1. STM32F103_study52_The punctual atoms(STM32 The running light experiment )
  2. Kinect使用系列
  3. Python游戏开发,pygame模块,Python实现记忆翻牌小游戏
  4. jpg转bmp c语言 linux,C语言实现BMP转换JPG的方法
  5. win查看服务器主板型号,Win10怎么看电脑主板型号?
  6. 7.2 可分离变量的微分方程
  7. [算法]算法学习05
  8. Laser-export绿光、红外及紫外波段的CW、脉冲激光器DPSS激光器
  9. android备忘录的开发总结报告,android备忘录
  10. Linux系统引导过程及引导修复