1

运行 select 语句以便稍后可以将输出插入回 SQL 的最直接方法是什么?数据集的大小会非常小,(可能少于 100 行)。我意识到有特定于数据库的导入/导出工具,但我想知道这是否可以仅使用 SQL 完成(可能还有一些 unix 命令行)。

编辑:

为了澄清,我想保存一组行:

select * from my_table where category='test'

然后,一段时间后,我希望将那些匹配的行重新插入到同一个表中。我假设 SQL 选择输出将被保存到一个文件中,并且该文件将通过 sql 命令行实用程序重新播放。

4

3 回答 3

2

一种方法是通过将一些字符串连接在一起以生成 INSERT 语句来生成 SQL。假设您使用的是 MSSQL:

SELECT'INSERT INTO Table1(Col1,Col2) VALUES('+CAST(Col1 AS VARCHAR(500))+',' +CAST(Col2 AS VARCHAR(500))+')' FROM Table1  

这不是一个很好的方法,因为它显然不能很好地扩展,但对于小型用途来说它并不算太糟糕,特别是如果你想要一个快速的答案。

我不知道您的数据库是如何构建的,但请确保您记得检查您插入的数据不会受到任何 PK / FK 约束的影响。

另请查看以下问题:为 SQL Server 表自动生成 INSERT 语句的最佳方法是什么?

您还可以考虑使用 BCP http://msdn.microsoft.com/en-us/library/aa196743(v=sql.80).aspx 用于 SQL BCP 的 google 会向您显示大量结果,这应该会有所帮助。

我知道您想要基于代码的解决方案,但我只想提一下,您还可以从 SQL Management Studio 导出此类数据(假设您正在使用该数据)。

于 2012-05-14T14:36:53.403 回答
0

我不确定我是否理解正确,但您想运行选择并将结果插入到同一命令的表中?

不确定是否可以完成,但我认为最像你想要的是 OUTPUT 语句:

declare @mytables table
(
   name varchar(50)
)

INSERT INTO @mytables    
output inserted.*   
select name 
from sys.tables

在这里,您将插入@mytables查询结果并使用子句select name from sys.tables呈现结果OUTPUT

于 2012-05-14T14:28:21.710 回答
0

如果数据库是TableA { Id, Column1, Column2 }

SELECT 
     'INSERT INTO [TableA] ([Id], [Column1], [Column2])' 
     + VALUES (' + [Id] + ', ''' + [Column1] + ''', ''' + [Column2] + ''')'
FROM TableA

结果将是:

INSERT INTO [TableA] ([Id], [Column1], [Column2]) VALUES (1, 'Value1', 'Value2')
INSERT INTO [TableA] ([Id], [Column1], [Column2]) VALUES (2, 'Value11', 'Value22')

然后您可以将结果复制到文件中

于 2012-05-14T14:37:44.263 回答