SELECT INSERT INTO 语句的值
Posted
技术标签:
【中文标题】SELECT INSERT INTO 语句的值【英文标题】:SELECT values of an INSERT INTO statement 【发布时间】:2015-10-07 03:36:31 【问题描述】:我需要从 table1 中选择几列。我只需要插入其中一列以及一些任意硬编码数据并将其插入到 table2 中,同时还可以取回原始的 select 语句。
基本上,我想获得我的 INSERT INTO 语句的结果,而不是我在 SSMS 中获得的“(1 行受影响)”。
有没有办法做到这一点?
这是一个 SQLFiddle: http://sqlfiddle.com/#!3/e9beb/3
那些记录会很好地插入。但是,我希望我的 SELECT 语句的结果能够返回给我,这样我就可以一次完成所有操作,而无需多次读取或旅行。这可能吗?
【问题讨论】:
【参考方案1】:您可以使用OUTPUT
子句:
INSERT INTO Table2
OUTPUT inserted.*
SELECT Phrase, 'This is an automatic note by the system', GETDATE(), 1
FROM Table1
【讨论】:
【参考方案2】:使用批处理语句并将中间结果存储在表变量中:
DECLARE @intermediate TABLE (
col1 type,
col2 type,
col3 type
);
INSERT INTO @intermediate VALUES ( ... );
INSERT INTO destinationTable SELECT * FROM @intermediate;
SELECT @intermediate;
如果在代码中使用它,您可以将所有这些都放在一个命令文本字符串中。
【讨论】:
【参考方案3】:你有没有尝试过这样的事情:
INSERT INTO Table1 (
SELECT Phrase, Notes, GetDate, 1
FROM Table2
UNION
SELECT Phrase, 'This is an automatic note by the system', GETDATE(), 1
UNION
)
【讨论】:
以上是关于SELECT INSERT INTO 语句的值的主要内容,如果未能解决你的问题,请参考以下文章
SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解
oracle SELECT INTO 和 INSERT INTO SELECT 两种表复制语句详解
SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
使用 select 语句编写 Sql insert into 语句