gpt4 book ai didi

mysql - 当没有匹配项时,CASE 语句将我的所有值更新为 NULL?

转载 作者:行者123 更新时间:2023-12-02 01:07:11 25 4
gpt4 key购买 nike

我在使用 MySql 中的 CASE 语句时遇到问题。我在下面添加了一些代码作为我正在尝试做的事情的示例。我认为如果 WHEN 语句中没有匹配项,则不会发生任何更改,但这似乎并没有发生。

我在 my_contacts 表中没有 contact_id 值为 66 的记录,因此我认为不会发生任何事情,但 zip_code 列中的所有值都会更改为 null。为什么是这样?

UPDATE my_contacts
SET zip_code =
CASE
WHEN contact_id = 66 THEN '33333'
END;
<小时/>

如何使用案例只更新几条记录?例如,我只想更新与 contact_id = 1 和 contact_id = 2 匹配的记录。它确实更新了这两条记录,但也将现有的邮政编码从“90004”更改为 NULL,为什么呢?

UPDATE my_contacts 
SET zip_code =
CASE
WHEN contact_id = 1 THEN '94301'
WHEN contact_id = 2 THEN '08540'
END;

查询正常,3 行受影响(0.01 秒)匹配行:5 已更改:3 警告:0

最佳答案

您错误地使用了CASE。使用 WHERE 子句进行条件更新:

UPDATE my_contacts SET zip_code = '33333' WHERE contact_id = 66;

CASE 表达式仅决定返回什么值,而不决定哪些行受到影响。来自 documentation :

If there [is] no matching result value, the result after ELSE is returned, or NULL if there is no ELSE part.

所以你正在做的事情相当于:

UPDATE my_contacts
SET zip_code = CASE WHEN contact_id = 66 THEN '33333' ELSE NULL END
;
<小时/>

为了响应您的更新,您需要执行以下操作:

UPDATE my_contacts 
SET zip_code =
CASE
WHEN contact_id = 1 THEN '94301'
WHEN contact_id = 2 THEN '08540'
END
WHERE contact_id IN (1, 2)
;

但只有对少数记录执行此操作才有意义。请参阅这篇文章了解更多可扩展的解决方案:MySQL bulk INSERT or UPDATE

关于mysql - 当没有匹配项时,CASE 语句将我的所有值更新为 NULL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19017462/

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