這樣的:有一張表number_prices: 兩個(gè)主要字段 number varchar(4) 和 price int。number字段的值從‘0000’~‘9999’,每一條記錄現(xiàn)在有一個(gè)規(guī)則f來確定price的值,規(guī)則是: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貢獻(xiàn)1874條經(jīng)驗(yàn) 獲得超12個(gè)贊
我的建議是把數(shù)據(jù)讀出來,用代碼去做匹配,然后生成這種SQL代碼。
update table_name set price=10 where id=1234;
最后把這堆SQL丟進(jìn)去執(zhí)行

慕神8447489
TA貢獻(xiàn)1780條經(jīng)驗(yàn) 獲得超1個(gè)贊
我優(yōu)先考慮過正則表達(dá)式來解決問題,但發(fā)現(xiàn)mysql不支持反向引用
REGEXP:
AAAA:([0-9])\1{3}
ABBA:([0-9])([0-9])\2\1
AABB:([0-9])\1([0-9])\2
所以放棄正則后只能用最原始的if else方式,當(dāng)然mysql的實(shí)現(xiàn)要變成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;
添加回答
舉報(bào)
0/150
提交
取消