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

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

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

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

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

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


当前回答

为了获得带有过滤记录的INSERT语句(WHERE QUERY),您可以

右击表脚本表>创建到>新的查询 用temp_table重命名 现在运行 选择到temp_table从你的第一个表,现在你的标准在这里

这样你的临时表将只有你想要的记录, 现在通过运行由@Mike Ritacco with DATA ONLY解释的脚本向导,您将得到确切的插入语句。

其他回答

不要使用插入,使用BCP

我使用的是SSMS 2008版本10.0.5500.0。在这个版本中,作为生成脚本向导的一部分,下面是一个屏幕,而不是一个高级按钮。在本例中,我只想插入数据而不需要create语句,因此必须更改两个圈起来的属性

如果您更愿意使用谷歌表,请使用SeekWell将表发送到表中,然后在日程表上插入行,因为它们被添加到表中。

请参见这里的逐步过程,或在这里观看该功能的视频演示。

你可以用我几年前写的这个简单而免费的应用程序生成INSERT或MERGE语句: 数据脚本编写器(Windows桌面应用程序)

此外,我最近还写了一篇关于这些工具以及利用SSDT部署数据数据库的方法的博客文章。了解更多信息: 从SSDT项目为数据库编写脚本并部署数据

也许你可以试试SQL Server发布向导 http://www.microsoft.com/downloads/details.aspx?FamilyId=56E5B1C5-BF17-42E0-A410-371A838E570A&displaylang=en

它有一个向导,帮助您编写插入语句。