mysql update case 更新字段值不固定的操作
在處理批量更新某些數(shù)據(jù)的時(shí)候,如果跟你更新的字段的值都一樣,比如某個(gè)狀態(tài)都更新為某個(gè)固定值,
直接用update table set xxx=xxx where xxx=xxx 這種即可如果要更新的字段的值是不固定的,用下面的update case when where 這種方式就更方便了
UPDATE tablename set a1= CASE userid WHEN 1 THEN a1+5 WHEN 2 THEN a1+2 END,a2= CASE userid WHEN 1 THEN a2-5 WHEN 2 THEN a2-2ENDwhere userid in (1,2)
用update case when 更新的時(shí)候一定要帶上 where 條件,否則會(huì)更新整張表,后果很嚴(yán)重。
補(bǔ)充:Mysql update && case when 聯(lián)合使用 批量更新
直接碼sql:
room字段值為 18F-N01 這種格式UPDATE t_report SET room = CONCAT_WS( ’-’, SUBSTRING_INDEX(room, ’-’, 1) , CASE SUBSTRING_INDEX(room, ’-’, -1) WHEN ’N01’ THEN ’N02’ WHEN ’N02’ THEN ’N01’ WHEN ’N03’ THEN ’N11’ WHEN ’N04’ THEN ’N10’ WHEN ’N05’ THEN ’N09’ WHEN ’N06’ THEN ’N08’ WHEN ’N07’ THEN ’N07’ WHEN ’N08’ THEN ’N06’ WHEN ’N09’ THEN ’N05’ WHEN ’N10’ THEN ’N03’ END )WHERE rid IN ( SELECT rid FROM t_report WHERE rdate = ’190306’ AND ordinal BETWEEN ’23’ AND ’32’)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. Oracle數(shù)據(jù)庫(kù)PL/SQL過程調(diào)試的輸出方法2. 使用MySqldump命令導(dǎo)出數(shù)據(jù)時(shí)的注意3. Mysql入門系列:MYSQL表達(dá)式求值和MYSQL類型轉(zhuǎn)換4. Windwos下MySQL 64位壓縮包的安裝方法學(xué)習(xí)記錄5. ACCESS轉(zhuǎn)SQL數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能6. MySQL基礎(chǔ)教程9 —— 函數(shù)之日期和時(shí)間函數(shù)7. Mysql 實(shí)現(xiàn)字段拼接的三個(gè)函數(shù)8. 不要忽視Oracle 10g STATSPACK新功能9. Mybatis傳入List實(shí)現(xiàn)批量更新的示例代碼10. SQL Server 2005 Reporting Services的一個(gè)bug及其解決方法
