3

我有一个 SQL Server 2005 数据库,我希望能够立即重新创建它。我希望能够指向我的数据库并生成一套完整的脚本,这些脚本不仅会创建数据库中的所有表/视图/存储过程/函数,还会用数据填充所有表。

有没有任何工具可以做到这一点?是否有任何开源或免费工具可以做到这一点?

4

3 回答 3

7

数据库发布向导是一个很棒的小工具。它的 OSS 和免费的,这是很难被击败的。

于 2008-08-20T15:25:21.177 回答
1

我一直做的是让 MS SQL Management Studio 创建脚本来重建数据库和空表。然后我使用另一个脚本生成一个 ms-dos 批处理文件,以通过“bcp”导出/导入数据。请参阅下面的 sql。

/* this is used to export */
use databaseXXX
select ('bcp databaseXXX..' + name + ' OUT ' + name + ' /eErrors.txt /b100 /n /Usa /Ppwd /Sserver') as bcp 
from 
  sysobjects 
where 
  type = 'U' 
order by 
  [name]


/* this is used to import */
use databaseXXX
select ('bcp databaseXXX..' + name + ' IN ' + name + ' /E /eErrors.txt /b100 /n /Usa /Ppwd /Sserver') as bcp 
from 
  sysobjects 
where 
  type = 'U' 
order by 
  [name]

每次都为我工作,而且很快。如果您将表生成脚本保存在文件中,您也可以通过 sqlcmd 命令将其放入批处理文件中。

于 2008-08-20T15:32:44.247 回答
0

检查下面的过程,该过程将创建一个脚本,该脚本将生成一个表及其所有数据。您可以将其包装在另一个存储过程中,该过程迭代所有表并生成一个大型脚本,该脚本将从头开始重新生成所有内容。

http://anastasiosyal.com/archive/2007/04/25/5.aspx

编辑:似乎 Will 找到了一个更好的解决方案 +1 给 Will

于 2008-08-20T15:25:15.873 回答