作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下类型的 SQL:
UPDATE photo AS f
LEFT JOIN car AS c
ON f.car_id=c.car_id
SET f.photo_status=1
, c.photo_count=c.photo_count+1
WHERE f.photo_id IN ($ids)
基本上,两个表(car
和photo
)是相关的。 $ids 中的列表包含唯一的照片 ID,例如 (34, 87, 98, 12)。通过查询,我将该列表中每张照片的状态设置为 photo
表中的“1”,同时增加 car
表中的照片计数车在手边。
它有效,但有一个障碍:因为列表可以包含与同一辆车相关的多个照片 ID,所以照片计数只会增加一次。如果列表中有 10 张照片与同一辆车相关联,则 photo_count 将变为 1 ....而我想将其增加到 10。
有没有办法通过连接使每张照片单独发生递增,而不是 MySQL 为我想得太多?
我希望以上是有道理的。谢谢。
最佳答案
你可以用两个查询来做到这一点:
UPDATE car
SET photo_count = photo_count + (
SELECT count(*)
FROM photos
WHERE photo.car_id = car.car_id
AND photo_status = 0
AND photo_id IN ($ids)
);
UPDATE photo
SET photo_status = 1
WHERE photo_id IN ($ids);
关于MySQL UPDATE WHERE IN分别为每个列出的值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2474879/
我是一名优秀的程序员,十分优秀!