0

我需要从 table1 中选择几列。我只需要插入其中一个列以及一些任意硬编码数据并将其插入到 table2 中,同时还需要返回原始的 select 语句。

基本上我想得到我的 INSERT INTO 语句的结果,而不是我在 SSMS 中得到的“(1 行受影响)”。

有没有办法做到这一点?


这是一个 SQLFiddle: http ://sqlfiddle.com/#!3/e9beb/3

这些记录将插入就好了。但是,我希望我的 SELECT 语句的结果能够返回给我,这样我就可以一次完成所有操作,而无需多次读取或旅行。这可能吗?

4

3 回答 3

2

您可以使用该OUTPUT子句:

INSERT INTO Table2
OUTPUT inserted.*
SELECT Phrase, 'This is an automatic note by the system', GETDATE(), 1
FROM Table1
于 2015-10-07T03:48:59.933 回答
2

使用批处理语句并将中间结果存储在表变量中:

DECLARE @intermediate TABLE (
    col1 type,
    col2 type,
    col3 type
);
INSERT INTO @intermediate VALUES ( ... );
INSERT INTO destinationTable SELECT * FROM @intermediate;
SELECT @intermediate;

如果从代码中使用它,您可以将所有这些都放在一个命令文本字符串中。

于 2015-10-07T03:40:59.657 回答
0

你有没有尝试过这样的事情:

INSERT INTO Table1 (
SELECT Phrase, Notes, GetDate, 1
FROM Table2
UNION
SELECT Phrase, 'This is an automatic note by the system', GETDATE(), 1
UNION
)
于 2015-10-07T03:43:28.307 回答