第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

需求如下,請問我該怎樣寫sql語句?

需求如下,請問我該怎樣寫sql語句?

蠱毒傳說 2023-04-05 13:09:11
這樣的:有一張表number_prices: 兩個主要字段 number varchar(4) 和 price int。number字段的值從‘0000’~‘9999’,每一條記錄現(xiàn)在有一個規(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貢獻1874條經(jīng)驗 獲得超12個贊

我的建議是把數(shù)據(jù)讀出來,用代碼去做匹配,然后生成這種SQL代碼。

update table_name set price=10 where id=1234;

最后把這堆SQL丟進去執(zhí)行


查看完整回答
反對 回復 2023-04-07
?
慕神8447489

TA貢獻1780條經(jīng)驗 獲得超1個贊

我優(yōu)先考慮過正則表達式來解決問題,但發(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方式,當然mysql的實現(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;


查看完整回答
反對 回復 2023-04-07
  • 2 回答
  • 0 關注
  • 161 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號