在 INSERT 语句中将 OUTPUT INTO 与 from_table_name 一起使用

ANi*_*sus 8 sql t-sql sql-server output-clause

Microsoft 的 OUTPUT Clause 文档表示您可以在 OUTPUT 子句的列名中使用from_table_name 。

有两个例子:

是否也可以在INSERT 语句中使用它?

INSERT INTO T ( [Name] )
OUTPUT S.Code, inserted.Id INTO @TMP -- The multi-part identifier "S.Code" could not be bound.
SELECT [Name] FROM S;
Run Code Online (Sandbox Code Playgroud)

使用表变量的失败示例

-- A table to insert into.
DECLARE @Item TABLE (
    [Id] [int] IDENTITY(1,1),
    [Name] varchar(100)
);
-- A table variable to store inserted Ids and related Codes
DECLARE @T TABLE (
    Code varchar(10),
    ItemId  int
);
-- Insert some new items
WITH S ([Name], Code) AS (
    SELECT 'First', 'foo'
    UNION ALL SELECT 'Second', 'bar'
    -- Etc.
)
INSERT INTO @Item ( [Name] )
OUTPUT S.Code, inserted.Id INTO @T -- The multi-part identifier "S.Code" could not be bound.
SELECT [Name] FROM S;
Run Code Online (Sandbox Code Playgroud)

Cai*_*ard 5

不,因为 INSERT 没有 FROM;它有一组由 VALUES 关键字或查询准备的值(即使该查询有 FROM,您应该认为它已经运行并在插入时转换为值块)完成;没有s.code了)

如果您想从驱动插入的表中输出某些内容,则需要使用从不匹配任何记录的合并语句(因此它只是插入),或者可能将所有数据插入@tmp,然后从@tmp插入到真实表中 - @tmp 因此仍然是插入的行的记录,只是它是为了驱动插入而创建的,而不是作为插入的结果(注意它不会包含计算列)