- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在使用 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, orNULL
if there is noELSE
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/
我正在使用 Gunicorn 为 Django 应用程序提供服务,它工作正常,直到我将其超时时间从 30 秒更改为 900000 秒,我不得不这样做,因为我有一个用例需要上传和处理一个巨大的文件(过程
我有一个带有非常基本的管道的Jenkinsfile,它可以旋转docker容器: pipeline { agent { dockerfile { args '-u root' } } stag
在学习 MEAN 堆栈的过程中,我遇到了一个问题。每当我尝试使用 Passport 验证方法时,它都不会返回任何响应。我总是收到“localhost没有发送任何数据。ERR_EMPTY_RESPONS
在当今的大多数企业堆栈中,数据库是我们存储所有秘密的地方。它是安全屋,是待命室,也是用于存储可能非常私密或极具价值的物品的集散地。对于依赖它的数据库管理员、程序员和DevOps团队来说,保护它免受所
是否可以创建像图片上那样的边框?只需使用 css 边框属性。最终结果将是没 Angular 盒子。我不想添加额外的 html 元素。我只想为每个 li 元素添加 css 边框信息。 假设这是一个 ul
我是一名优秀的程序员,十分优秀!