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

这样的:
有一张表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,
    ...


蛊毒传说
浏览 118回答 2
2回答

HUWWW

我的建议是把数据读出来,用代码去做匹配,然后生成这种SQL代码。update table_name set price=10 where id=1234;最后把这堆SQL丢进去执行

慕神8447489

我优先考虑过正则表达式来解决问题,但发现mysql不支持反向引用REGEXP:AAAA:([0-9])\1{3}ABBA:([0-9])([0-9])\2\1AABB:([0-9])\1([0-9])\2所以放弃正则后只能用最原始的if else方式,当然mysql的实现要变成case when thenUPDATE&nbsp;temp&nbsp;t&nbsp;SET&nbsp;t.`price`=&nbsp; CASE&nbsp;WHEN&nbsp;(SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,2,1)&nbsp;AND&nbsp; SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,3,1)&nbsp;AND&nbsp;SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,4,1))=TRUE&nbsp; THEN&nbsp;100&nbsp;WHEN&nbsp;(SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,2,1)&nbsp;ANDSUBSTRING(t.`number`,3,1)=SUBSTRING(t.`number`,4,1)&nbsp;AND&nbsp;SUBSTRING(t.`number`,2,1)<>SUBSTRING(t.`number`,3,1))=TRUE THEN&nbsp;50WHEN&nbsp;(SUBSTRING(t.`number`,1,1)=SUBSTRING(t.`number`,4,1)&nbsp;ANDSUBSTRING(t.`number`,2,1)=SUBSTRING(t.`number`,3,1)&nbsp;AND&nbsp;SUBSTRING(t.`number`,1,1)<>SUBSTRING(t.`number`,2,1))=TRUE THEN&nbsp;40ELSE&nbsp;0&nbsp;END;
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

MySQL