gpt4 book ai didi

MySQL UPDATE WHERE IN分别为每个列出的值?

转载 作者:行者123 更新时间:2023-12-01 00:16:01 24 4
gpt4 key购买 nike

我有以下类型的 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)

基本上,两个表(carphoto)是相关的。 $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/

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