mysql中,如何根据字符串的排列规则来更新?

发布于 2022-08-22 09:34:47 字数 316 浏览 15 评论 2

需求是这样的:
有一张表number_prices: 两个主要字段 number varchar(4) 和 price int。
number字段的值从‘0000’~‘9999’,每一条记录现在有一个规则f来确定price的值,规则是:

f:
    if number like 'AAAA' then price = 100,
    else if number like 'AABB' then price = 50,
    else if number like 'ABBA' then price = 40,
    ...

我该怎样写sql语句?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

毁梦 2022-08-25 09:39:31

我优先考虑过正则表达式来解决问题,但发现mysql不支持反向引用
REGEXP:
AAAA:([0-9])\1{3}
ABBA:([0-9])([0-9])\2\1
AABB:([0-9])\1([0-9])\2

所以放弃正则后只能用最原始的if else方式,当然mysql的实现要变成case when then

UPDATE temp t SET t.`price`= 
CASE WHEN (SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,2,1) AND 
SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,3,1) AND SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,4,1))=TRUE 
THEN 100 
WHEN (SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,2,1) AND
SUBSTRING(t.`number`,3,1)=SUBSTRING(t.`number`,4,1) AND SUBSTRING(t.`number`,2,1)<>SUBSTRING(t.`number`,3,1))=TRUE
THEN 50
WHEN (SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,4,1) AND
SUBSTRING(t.`number`,2,1)=SUBSTRING(t.`number`,3,1) AND SUBSTRING(t.`number`,1,1)<>SUBSTRING(t.`number`,2,1))=TRUE
THEN 40
ELSE 0 END;
山色无中 2022-08-22 14:52:04

我的建议是把数据读出来,用代码去做匹配,然后生成这种SQL代码。

update table_name set price=10 where id=1234;

最后把这堆SQL丢进去执行

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文