SQL server存储过程中连续多条update语句,部分成功,部分失败,为什么?

如:

update tmp_table set ikitem=isnull(FItemID,0) from  t_item where fnumber=kitem  and   FItemClassID =3501

连续几个update都和上面的语句结构相同,操作同一张表,但要update的字段不同,条件也不同

同一条update里明明有多个符合条件的记录,但只有其中几条成功update,其他失败;语句是没问题的,单独拿出来执行是可以全部update成功的。

放在存储过程里就是部分失败QAQ

加了事务,try catch了也不行,到底是为什么啊QAQ

 

有些不允许更改吧.. 看报错

改成批处理测试一下,应该是有些条件的影响

谢谢大家,已经改好了,改成这样就好了:update tmp_table set tmp_table.ikitem=isnull(t_item.FItemID,0) from  t_item,tmp_table where t_item.fnumber=tmp_table.kitem  and   t_item.FItemClassID =3501 

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y