我有一个 SQL Server 2005 数据库,我希望能够立即重新创建它。我希望能够指向我的数据库并生成一套完整的脚本,这些脚本不仅会创建数据库中的所有表/视图/存储过程/函数,还会用数据填充所有表。
有没有任何工具可以做到这一点?是否有任何开源或免费工具可以做到这一点?
我有一个 SQL Server 2005 数据库,我希望能够立即重新创建它。我希望能够指向我的数据库并生成一套完整的脚本,这些脚本不仅会创建数据库中的所有表/视图/存储过程/函数,还会用数据填充所有表。
有没有任何工具可以做到这一点?是否有任何开源或免费工具可以做到这一点?
数据库发布向导是一个很棒的小工具。它的 OSS 和免费的,这是很难被击败的。
我一直做的是让 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 命令将其放入批处理文件中。
检查下面的过程,该过程将创建一个脚本,该脚本将生成一个表及其所有数据。您可以将其包装在另一个存储过程中,该过程迭代所有表并生成一个大型脚本,该脚本将从头开始重新生成所有内容。
http://anastasiosyal.com/archive/2007/04/25/5.aspx
编辑:似乎 Will 找到了一个更好的解决方案 +1 给 Will