mysql中,如何根据字符串的排列规则来更新?
需求是这样的:
有一张表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 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我优先考虑过正则表达式来解决问题,但发现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
我的建议是把数据读出来,用代码去做匹配,然后生成这种SQL代码。
最后把这堆SQL丢进去执行