为了账号安全,请及时绑定邮箱和手机立即绑定

需求如下,请问我该怎样写sql语句?

需求如下,请问我该怎样写sql语句?

蛊毒传说 2023-04-05 13:09:11
这样的:有一张表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,     ...
查看完整描述

2 回答

?
HUWWW

TA贡献1874条经验 获得超12个赞

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

update table_name set price=10 where id=1234;

最后把这堆SQL丢进去执行


查看完整回答
反对 回复 2023-04-07
?
慕神8447489

TA贡献1780条经验 获得超1个赞

我优先考虑过正则表达式来解决问题,但发现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) ANDSUBSTRING(t.`number`,3,1)=SUBSTRING(t.`number`,4,1) AND SUBSTRING(t.`number`,2,1)<>SUBSTRING(t.`number`,3,1))=TRUE
THEN 50WHEN (SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,4,1) ANDSUBSTRING(t.`number`,2,1)=SUBSTRING(t.`number`,3,1) AND SUBSTRING(t.`number`,1,1)<>SUBSTRING(t.`number`,2,1))=TRUE
THEN 40ELSE 0 END;


查看完整回答
反对 回复 2023-04-07
  • 2 回答
  • 0 关注
  • 112 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信