mysql update case 更新字段值不固定的操作
在處理批量更新某些數據的時候,如果跟你更新的字段的值都一樣,比如某個狀態都更新為某個固定值,
直接用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-2 END where userid in (1,2)
用update case when 更新的時候一定要帶上 where 條件,否則會更新整張表,後果很嚴重。
補充:Mysql update && case when 聯合使用 批量更新
直接碼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' )
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。
推薦閱讀:
- MySQL實現用逗號進行拼接、以逗號進行分割
- Mysql查詢所有表和字段信息的方法
- Mysql字段和java實體類屬性類型匹配方式
- MySQL 十大常用字符串函數詳解
- mysql單字段多值分割和合並的處理方法