微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用具有相同参数的select或update时受影响的行数不同 – PostgreSQL

我有两个带有相同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] 举报,一经查实,本站将立刻删除。

相关推荐