gpt4 book ai didi

mysql - SQL 无法运行 UPDATE 查询,因为一个表被指定了两次

转载 作者:搜寻专家 更新时间:2023-10-30 20:15:53 24 4
gpt4 key购买 nike

我是 SQL 的新手,我不能很好地利用其他类似的问题。

我想给所有合住同一栋房子的人提供 30% 的折扣,所以我有一张包含 ID、价格和房屋名称的表格。

这是我的查询:

UPDATE person
SET price= price*0.97
WHERE house IN (SELECT p.house FROM person p GROUP BY p.house HAVING COUNT(*) >2);

它说“表被指定了两次,既作为‘更新’的目标,又作为单独的数据源”,但我不知道有其他方法可以保存房子的字符串并比较其他声音。

我应该如何进行?

最佳答案

这是 MySQL 的限制。解决方案是使用 JOIN:

UPDATE person p JOIN
(SELECT p.house
FROM person p
GROUP BY p.house
HAVING COUNT(*) > 2
) ph
ON p.house = ph.house
SET p.price = p.price * 0.97;

JOIN 代替 IN 运算符进行过滤。

关于mysql - SQL 无法运行 UPDATE 查询,因为一个表被指定了两次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40563362/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com