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

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条)

报告相同问题?

悬赏问题

  • ¥15 gwas 分析-数据质控之过滤稀有突变中出现的问题
  • ¥15 没有注册类 (异常来自 HRESULT: 0x80040154 (REGDB_E_CLASSNOTREG))
  • ¥15 知识蒸馏实战博客问题
  • ¥15 用PLC设计纸袋糊底机送料系统
  • ¥15 simulink仿真中dtc控制永磁同步电机如何控制开关频率
  • ¥15 用C语言输入方程怎么
  • ¥15 网站显示不安全连接问题
  • ¥15 51单片机显示器问题
  • ¥20 关于#qt#的问题:Qt代码的移植问题
  • ¥50 求图像处理的matlab方案