qq_18997393
2019-03-12 20:58
采纳率: 50%
浏览 1.3k
已采纳

sql server MERGE INTO 同一个表,报错

MERGE INTO FACTORY_STATISTICS f USING ( SELECT COUNT ( 1 ) AS COUNT FROM FACTORY_STATISTICS ff WHERE ff.FACTORYCODE = '1000' AND ff.MATERIALID = 'T01100' ) CONDITION ON ( CONDITION.count > 0 ) 
WHEN MATCHED THEN
UPDATE 
    SET f.PARTAVANUM = f.PARTAVANUM + 1,
    f.MATCHAVANUM = f.MATCHAVANUM + 1,
    f.AVAILABLENUM = f.AVAILABLENUM + 1,
    f.TOTALNUM = f.TOTALNUM + 1 
    WHEN NOT MATCHED 
    AND f.FACTORYCODE = '1000' 
    AND f.MATERIALID = 'T01100' THEN
    INSERT (
    f.ID,
    f.FACTORYCODE,
    f.MATERIALID,
    f.PARTAVANUM,
    f.PARTFREEZENUM,
    f.PARTLOCKNUM,
    f.MATCHAVANUM,
    f.MATCHFREEZENUM,
    f.MATCHLOCKNUM,
    f.AVAILABLENUM,
    f.FREEZENUM,
    f.LOCKNUM,
    f.TotalNum 
    )
VALUES
    (
    '1',
    '1',
    '1',
    '1',
    '1',
    '1',
    '1',
    '1',
    '1',
    '1',
    '1',
    '1',
    '1' 
    )
```[42000] [Microsoft][SQL Server Native Client 11.0][SQL Server]MERGE 语句中使用的插入列列表中不能包含多部分标识符。请改用单部分标识符。 (10739)
  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

2条回答 默认 最新

  • l_w610 2019-03-13 15:20
    最佳回答

    1、目标表字段不能作为条件判断

    WHEN NOT MATCHED  AND f.FACTORYCODE = '1000'   AND f.MATERIALID = 'T01100' THEN
    

    2、你INSERT 语句中行值表达式的数目超出了设置 行值的最大允许值。
    3、更新同一张表,完全没必要merge,再者你的f和ff并无关系,没有任何匹配和不匹配可言。

    评论
    解决 无用
    打赏 举报
查看更多回答(1条)

相关推荐 更多相似问题