gpt4 book ai didi

mysql 大小写函数

转载 作者:行者123 更新时间:2023-11-29 04:48:55 28 4
gpt4 key购买 nike

我有以下查询,它正在更新缺少连字符的 MAC 地址,但对于已经拥有它们的其他人,它正在将它们更改为空。尝试更新一列中的值。

UPDATE mytable SET MAC =
CASE
WHEN MAC NOT LIKE '%-%'
THEN UPPER(CONCAT(SUBSTR(MAC,1,2),'-', SUBSTR(MAC,3,2),'-', SUBSTR(MAC,5,2),'-', SUBSTR(MAC,7,2),'-', SUBSTR(MAC,9,2),'-', SUBSTR(MAC,11,2)))
END;

任何建议都会很棒。

谢谢

最佳答案

只需添加一个 ELSE 将值设置为其当前值的情况:

UPDATE mytable SET MAC =
CASE
WHEN MAC NOT LIKE '%-%'
THEN UPPER(CONCAT(SUBSTR(MAC,1,2),'-', SUBSTR(MAC,3,2),'-', SUBSTR(MAC,5,2),'-', SUBSTR(MAC,7,2),'-', SUBSTR(MAC,9,2),'-', SUBSTR(MAC,11,2)))
/* Else case sets it to its current value to avoid NULL */
ELSE MAC
END;

也可以使用 WHERE 子句,这样不应更新的行首先不会匹配。在这种情况下,这可能是更合适的操作,除非您在 CASE

中有其他条件要应用
UPDATE mytable 
SET MAC = UPPER(CONCAT(SUBSTR(MAC,1,2),'-', SUBSTR(MAC,3,2),'-', SUBSTR(MAC,5,2),'-', SUBSTR(MAC,7,2),'-', SUBSTR(MAC,9,2),'-', SUBSTR(MAC,11,2)))
WHERE MAC NOT LIKE '%-%'

关于mysql 大小写函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14283504/

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