您现在的位置是:网站首页> 编程资料编程资料
mysql update case 更新字段值不固定的操作_Mysql_
2023-05-27
416人已围观
简介 mysql update case 更新字段值不固定的操作_Mysql_
在处理批量更新某些数据的时候,如果跟你更新的字段的值都一样,比如某个状态都更新为某个固定值,
直接用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' )
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
您可能感兴趣的文章:
相关内容
- mysql密码中有特殊字符&在命令行下登录的操作_Mysql_
- mysql修改记录时update操作 字段=字段+字符串_Mysql_
- Mysql 中文排序规则说明_Mysql_
- 基于mysql 默认排序规则的坑_Mysql_
- Mysql主键UUID和自增主键的区别及优劣分析_Mysql_
- 如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog_Mysql_
- MySQL 日志相关知识总结_Mysql_
- Mysql桌面工具之SQLyog资源及激活使用方法告别黑白命令行_Mysql_
- Mysql避免重复插入数据的4种方式_Mysql_
- 如何在mysql进行查询缓存及失败的解决方法_Mysql_
