【问题标题】:Merge insert with select statement将插入与选择语句合并
【发布时间】:2013-01-16 18:46:31
【问题描述】:

这对我有用

MERGE Table1 AS tgt
USING
(
    SELECT
        TOP 1
        *
    FROM
        Table2,
        (
            SELECT
                itmid
            FROM
                Table3
            WHERE
                id = @id
        ) as a
    WHERE
        id = @id
) AS src
ON ( tgt.id = src.id )
WHEN MATCHED THEN
    UPDATE SET qty = qty + @qty
WHEN NOT MATCHED THEN
    INSERT itmid
    VALUES itmid;

但是当我这样改变时,它不起作用,在最后一个 select 附近显示错误

MERGE Table1 AS tgt
USING
(
    SELECT
        TOP 1
        *
    FROM
        Table2
    WHERE
        id = @id
) AS src
ON ( tgt.id = src.id )
WHEN MATCHED THEN
    UPDATE SET qty = qty + @qty
WHEN NOT MATCHED THEN
    INSERT itmid
    SELECT itmid FROM Table3 WHERE id = @id;

【问题讨论】:

  • 所有附加字段都应该在 USING 子句中传递(添加子选择列或加入另一个表)

标签: sql sql-server merge sql-server-2008-r2


【解决方案1】:

根据MSDN docs

<merge_not_matched>::=
{
    INSERT [ ( column_list ) ] 
        { VALUES ( values_list )
        | DEFAULT VALUES }
}

INSERT 的语法 来自 SELECT like:

  WHEN NOT MATCHED THEN
            INSERT itmid SELECT itmid FROM Table3 WHERE id=@id;

不允许!

我会尝试通过与Table3 再次合并来解决您的问题。

【讨论】:

    【解决方案2】:

    这样做

     MERGE Table1 AS tgt
     USING (SELECT TOP 1 * FROM Table2
            WHERE id = @id) AS src
    ON (tgt.id = src.id)
                WHEN MATCHED THEN UPDATE SET qty = qty + @qty
                WHEN NOT MATCHED THEN
                    INSERT (itmid) 
                     SELECT itmid FROM Table3 WHERE id=@id;
    

    根据http://msdn.microsoft.com/en-us/library/bb522522(v=sql.105).aspx应该可以正常工作

    对不起,我解释错了,我原来的答案是

    MERGE Table1 AS tgt
         USING (SELECT TOP 1 * FROM Table2
                WHERE id = @id) AS src
        ON (tgt.id = src.id)
                    WHEN MATCHED THEN UPDATE SET qty = qty + @qty
                    WHEN NOT MATCHED THEN
                        INSERT (itmid) values (SELECT top 1 itmid FROM Table3 WHERE id=@id);
    

    由于合并插入一次需要一个插入,并且多次插入可能会失败。

    【讨论】:

    • 此语法不作为合并语句的一部分存在。我也无法想象查询计划会是什么样子。
    • INSERT () VALUES (SELECT...) 对于 MERGE 语法无效。你不能“欺骗”它。请删除它,因为您显然没有测试过您的代码。
    • 此语法不存在
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-05-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-03-18
    • 1970-01-01
    相关资源
    最近更新 更多