我有两个带有相同Join和Where子句的sql语句,但我有一个问题,就是select语句给了我不同数量的行(在我的情况下是42)因为update语句会改变(在我的情况下是80,就是所有行的表).
这是第一个(我用它来检查将受影响的行数):
SELECT COUNT(*) FROM classes AS c INNER JOIN programs AS p ON c.Pr_ID = p.Pr_ID AND p.Ma_ID = 8; --> returns: 32
这里是第二个(这使得工作,它将更新表类的一个字段):
UPDATE classes SET Cl_Status = 3 FROM classes AS c INNER JOIN programs AS p ON c.Pr_ID = p.Pr_ID AND p.Ma_ID = 8; --> returns: 80 (!)
第一个和第二个语句之间的区别只是第一行,其他一切都是相同的.
有谁知道在两个语句中获得相同行数的变化是什么?
解决方法
你想要的是什么
UPDATE classes SET CL_Status = 3 FROM programs WHERE classes.Pr_ID = programs.Pr_ID AND programs.Ma_ID = 8
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。