我们正在编写一个新的应用程序,在进行测试时,我们将需要一堆虚拟数据。我已经通过使用MS Access将excel文件转储到相关表中添加了这些数据。

每隔一段时间,我们想要“刷新”相关的表,这意味着将它们全部删除,重新创建它们,并运行已保存的MS Access追加查询。

第一部分(删除和重新创建)是一个简单的sql脚本,但最后一部分让我畏缩。我想要一个单独的设置脚本,它有一堆insert来重新生成虚拟数据。

我现在有数据在表格里。从该数据集自动生成一个大的INSERT语句列表的最佳方法是什么?

我能想到的唯一方法是将表保存到excel表格中,然后编写excel公式为每一行创建一个INSERT,这肯定不是最好的方法。

我使用2008 Management Studio连接到SQL Server 2005数据库。


当前回答

微软应该宣传SSMS 2008的这个功能。您正在寻找的特性内置于Generate Script实用程序中,但是该功能在默认情况下是关闭的,并且在编写表脚本时必须启用。

这是一个快速运行,为您表中的所有数据生成INSERT语句,不使用SQL Management Studio 2008脚本或插件:

右键单击数据库,转到Tasks > Generate Scripts。 选择要针对其生成脚本的表(或对象)。 转到设置脚本选项选项卡,然后单击高级按钮。 在“常规”类别中,转到“脚本的数据类型” 有3个选项:仅模式、仅数据和模式和数据。选择适当的选项并单击OK。

然后,您将直接从SSMS中获取数据的CREATE TABLE语句和所有INSERT语句。

其他回答

生产数据库中有数据吗?如果是这样,您可以通过DTS设置数据的周期刷新。我们每周都在周末进行测试,每周都有干净、真实的测试数据是非常好的。

如果你还没有生产,那么你应该创建一个他们想要的数据库(新鲜的)。然后,复制该数据库并使用新创建的数据库作为您的测试环境。当你想要一个干净的版本时,只需再复制一遍干净的版本,就可以了。

你可以随心所欲地把它变得困难或简单。我更喜欢后者。

如果你已经有一个数据集,你所要做的就是在MS Access中添加一个动作查询:

insert into Table1("column list here")从Table2中选择"column list here"

注意:Table2可以是一个查询表,Table1和Table2可以是一个MS Access表或Sql Server表

不确定,如果我没理解错的话。

如果你有数据在MS-Access,你想把它移动到SQL Server -你可以使用DTS。 而且,我猜你可以使用SQL分析器来查看所有的INSERT语句。

sp_generate_inserts的第一个链接非常酷,这是一个非常简单的版本:

DECLARE @Fields VARCHAR(max); SET @Fields = '[QueueName], [iSort]' -- your fields, keep []
DECLARE @Table  VARCHAR(max); SET @Table  = 'Queues'               -- your table

DECLARE @SQL    VARCHAR(max)
SET @SQL = 'DECLARE @S VARCHAR(MAX)
SELECT @S = ISNULL(@S + '' UNION '', ''INSERT INTO ' + @Table + '(' + @Fields + ')'') + CHAR(13) + CHAR(10) + 
 ''SELECT '' + ' + REPLACE(REPLACE(REPLACE(@Fields, ',', ' + '', '' + '), '[', ''''''''' + CAST('),']',' AS VARCHAR(max)) + ''''''''') +' FROM ' + @Table + '
PRINT @S'

EXEC (@SQL)

在我的系统中,我得到了这样的结果:

INSERT INTO Queues([QueueName], [iSort])
SELECT 'WD: Auto Capture', '10' UNION 
SELECT 'Car/Lar', '11' UNION 
SELECT 'Scan Line', '21' UNION 
SELECT 'OCR', '22' UNION 
SELECT 'Dynamic Template', '23' UNION 
SELECT 'Fix MICR', '41' UNION 
SELECT 'Fix MICR (Supervisor)', '42' UNION 
SELECT 'Foreign MICR', '43' UNION 
...

我使用sqlite来做到这一点。我发现它对于创建scratch/test数据库非常非常有用。

sqlite3 foo。Sqlite .dump > foo_as_a_bunch_of_inserts.sql