作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试按照以下几行创建更新语句:
TABLE car: id | owner_id | type | status
车主可以拥有多辆汽车。
UPDATE car c
SET c.type = 1
WHERE c.owner_id IN ($ids)
AND c.status = [1 IF THIS OWNER HAS A CAR WITH 1, ELSE A CAR WITH 0] // ... ???
$ids 相当小(低于 50 个值)。
这看起来很简单,但我似乎无法理解它,因为我不能对同一个表使用带有 UPDATE 的 SELECT 子查询。
有人吗?
谢谢
最佳答案
您说您尝试了一个失败的查询,但不幸的是您还没有发布它,所以我猜是这样的:
UPDATE car c
SET c.type = 1
WHERE c.owner_id IN ($ids)
AND c.status = (SELECT MAX(c2.status) FROM car c2 WHERE c.owner_id = c2.owner_id)
发布您的实际查询会有所帮助,但现在我只是假设这是您尝试过的。如果你有一些稍微不同的东西,没关系......原理是一样的。正如您正确指出的那样,它失败了,因为您无法在一个查询中更新和选择同一个表。解决此错误的一种方法是将选择包装在另一个选择中:
UPDATE car c
SET c.type = 1
WHERE c.owner_id IN ($ids)
AND c.status = (SELECT * FROM
(SELECT MAX(c2.status) FROM car c2 WHERE c.owner_id = c2.owner_id)
AS T1)
令人惊讶的是,即使看起来它应该等同于第一个查询,它也会起作用。请注意,原始查询不起作用的原因是因为它没有正确锁定表。这种变通方法会诱使 MySQL 无论如何都允许查询,但您应该意识到在多用户环境中使用它可能不安全。
关于MySQL:如何进行条件更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2576019/
我是一名优秀的程序员,十分优秀!