主页 > 知识库 > mysql update case 更新字段值不固定的操作

mysql update case 更新字段值不固定的操作

热门标签:外呼系统打电话上限是多少 南昌三维地图标注 武汉网络外呼系统服务商 曲靖移动外呼系统公司 啥是企业400电话办理 怎样在地图标注销售区域 地图标注费用是多少 百应电话机器人优势 电话外呼系统改号

在处理批量更新某些数据的时候,如果跟你更新的字段的值都一样,比如某个状态都更新为某个固定值,

直接用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+PostgreSQL批量插入更新insertOrUpdate
  • MySQL update set 和 and的区别
  • MySQL UPDATE 语句的非标准实现代码
  • Mysql update多表联合更新的方法小结
  • mysql事务select for update及数据的一致性处理讲解
  • MySQL UPDATE 语句一个“经典”的坑

标签:吉林 锦州 随州 甘南 沧州 荆州 资阳 黑河

巨人网络通讯声明:本文标题《mysql update case 更新字段值不固定的操作》,本文关键词  mysql,update,case,更新,字段,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《mysql update case 更新字段值不固定的操作》相关的同类信息!
  • 本页收集关于mysql update case 更新字段值不固定的操作的相关信息资讯供网民参考!
  • 推荐文章