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

本文分享了SQL中批量更新数据的方法,包括当更新字段值固定和不固定的情况。对于值固定的更新,可以直接使用UPDATE SET WHERE语句;而对于值不固定的更新,利用CASE WHEN配合WHERE子句可以实现。举例说明了如何使用CASE WHEN更新特定条件下房间号的格式。最后强调了在使用UPDATE CASE WHEN时务必加上WHERE条件,以避免全表更新的风险。内容涵盖了数据库操作的实用技巧,适合数据库管理员和开发者参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

直接用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'

)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持得牛网。如有错误或未考虑完全的地方,望不吝赐教。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值