本⼈从事的⼯作是数据库管理员,要维护多台服务器中的数据库,经常把某台服务器中的某个数据库移动到另外⼀台服务器,对数据的移动有些⼼得体会,希望和⼤家共同交流。
1. 通过⼯具DTS的设计器进⾏导⼊或导出
  DTS的设计器功能强⼤,⽀持多任务,也是可视化界⾯,容易操作,但知道的⼈⼀般不多,如果只是进⾏SQL Server数据库中部分表的移动,⽤这种⽅法,当然,也可以进⾏全部表的移动。在SQL Server Enterprise Manager中,展开服务器左边的+,选择数据库,右击,选择All tasks/(或All tasks/),进⼊向导模式,按提⽰⼀步⼀步⾛就⾏了,⾥⾯分得很细,可以灵活的在不同数据源之间复制数据,很⽅便的。⽽且可以另存成DTS包,如果以后还有相同的复制任务,直接运⾏DTS包就⾏,省时省⼒。也可以直接打开DTS设计器,⽅法是展开服务器名称下⾯的Data Transformation Services,选Local Packages,在右边的窗⼝中右击,选New Package,就打开了DTS设计器。值得注意的是:如果源数据库要拷贝的表有外键,注意移动的顺序,有时要分批移动,否则外键主键,索引可能丢失,移动的时候选项旁边的提⽰说的很明⽩,或者⼀次性的复制到⽬标数据库中,再重新建⽴外键,主键,索引。
  其实建⽴数据库时,建⽴外键,主键,索引的⽂件应该和建表⽂件分开,⽽且⽤的数据⽂件也分开,并分别放在不同的驱动器上,有利于数据库的优化。
2. 利⽤Bcp⼯具
  这种⼯具虽然在SQL Server7的版本中不推荐使⽤,但许多数据库管理员仍很喜欢⽤它,尤其是⽤过SQL Server早期版本的⼈。Bcp有局限性,⾸先它的界⾯不是图形化的,其次它只是在SQL Server的表(视图)与⽂本⽂件之间进⾏复制,但它的优点是性能好,开销⼩,占⽤内存少,速度快。有兴趣的朋友可以查参考⼿册。
3. 利⽤备份和恢复
  先对源数据库进⾏完全备份,备份到⼀个设备(device)上,然后把备份⽂件复制到⽬的服务器上(恢复的速度快),进⾏数据库的恢复操作,在恢复的数据库名中填上源数据库的名字(名字必须相同),选择强制型恢复(可以覆盖以前数据库的选项),在选择从设备中进⾏恢复,浏览时选中备份的⽂件就⾏了。这种⽅法可以完全恢复数据库,包括外键,主键,索引。
4. 直接拷贝数据⽂件
  把数据库的数据⽂件(*.mdf)和⽇志⽂件(*.ldf)都拷贝到⽬的服务器,在SQL Server Query Analyzer中⽤语句进⾏恢复:
EXEC sp_attach_db @dbname = 'test',
@filename1 = 'd:\mssql7\data\test_data.mdf',
@filename2 = 'd:\mssql7\data\test_log.ldf'
这样就把test数据库附加到SQL Server中,可以照常使⽤。如果不想⽤原来的⽇志⽂件,可以⽤如下的命令:
EXEC sp_detach_db @dbname = 'test'
EXEC sp_attach_single_file_db @dbname = 'test',
@physname = 'd:\mssql7\data\test_data.mdf'
这个语句的作⽤是仅仅加载数据⽂件,⽇志⽂件可以由SQL Server数据库⾃动添加,但是原来的⽇志⽂件中记录的数据就丢失了。sqlserver备份表语句
5. 在应⽤程序中定制
  可以在应⽤程序(PB、VB)中执⾏⾃⼰编写的程序,也可以在Query Analyzer中执⾏,这种⽅法⽐较灵活,其实是利⽤⼀个平台连接到数据库,在平台中⽤的主要时SQL语句,这种⽅法对数据库的影响⼩,但是如果⽤到远程链接服务器,要求络之间的传输性能好,⼀般有两种语句:
  1> select ... into new_tablename where ...
  2> insert (into) old_tablename select ... from ... where ...
  区别是前者把数据插⼊⼀个新表(先建⽴表,再插⼊数据),后者是把数据插⼊已经存在的⼀个表中,我个⼈喜欢后者,因为在编程的结构上,应⽤的范围上,第⼆条语句强于前者。
6. SQL Server的复制功能
  SQL Server提供了强⼤的数据复制功能,也是最不易掌握的,具体应⽤请参考相关资料,值得注意的是要想成功进⾏数据的复制⼯作,有些条件是必不可少的:
  1>SQL Server Agent必须启动,MSDTC必须启动。
  2>所有要复制的表必须有主键。
  3>如果表中有text或image数据类型,必须使⽤with log选项,不能使⽤with no_log选项。
  另外max text repl size选项控制可以复制的⽂本和图像数据的规模,超过这个限制的操作将失败。
  4>在要进⾏复制的计算机上,应该⾄少是隐含共享,即共享名是C$或D$…。
  5>为SQL Server代理使⽤的Windows NT帐号不能是⼀个本地的系统帐号,因为本地的系统帐号不允许络存取。
  6>如果参与复制的服务器在另外的计算机域中,必须在这些域之间建⽴信任关系。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。