mysql同时更改多条数据源_Mysql快速批量更新多条记录不同值的语句

如果是要把Mysql多条数据的某个字段改成一样的值,那语句非常简单,例如把user表的部分用户状态改成 1,语句如下:

UPDATE user SET status=1 WHERE id in ('1001,1002,1003');

那如果要把多条user记录的备注字段改成不同的值,一般情况是使用foreach循环修改。我看了Yii2和ThinkPHP5框架的源码,均没有真正批量更新不同值的方法,ThinkPHP也是采用foreach的形式,然后启用事务机制,当某一条数据更新失败就回滚。例如ThinkPHP5的saveAll批量更新操作就是使用如下代码:

format,png

这种方案当同时更新大量数据的时候很多问题就来了,比如处理时间过长,甚至超时,如果数据库不支持事务机制,还会导致数据无法回滚,最终导致数据错乱。难道就没有一种像批量插入数据的语句来批量更新数据么?答案是有的!

我们采用Mysql的WHEN  THEN 来判断做处理,现在需要把多个user表的记录里的备注改成不同的值,语句如下:

UPDATE user

SET remark = CASE id

WHEN 1001 THEN '是小明介绍来的'

WHEN 1002 THEN '比较有钱'

WHEN 1003 THEN '这个客户来自火端官网'

END

WHERE id IN (1001,1002,1003)

没错,这样就可以一次性修改了多条记录的不同值,如果我们想修改备注字段的同时,还想把其他字段修改为不同的值,可以这样:

UPDATE user

SET remark = CASE id

WHEN 1001 THEN '是小明介绍来的'

WHEN 1002 THEN '比较有钱'

WHEN 1003 THEN '这个客户来自火端官网'

END,

realname = CASE id

WHEN 1001 THEN '田馥甄'

WHEN 1002 THEN '陈嘉桦'

WHEN 1003 THEN '任家萱'

END

WHERE id IN (1001,1002,1003)

如果要修改大量数据,就需要用动态语言把SQL语句循环组装一下,生成的语句会比较长,别以为这样会很麻烦,此方法批量更新会快很多倍。火端喜欢用数据说话,此类比较都会亲自测试对比,火端尝试使用foreach循环修改1000条数据,测试多次,平均耗时2.8秒,而采用此方法一次性批量更新,仅仅花了0.06秒!区别非常大,使用该方法批量更新是非常划算的。

如果需要使用它,建议大家自己封装一个方法,也可以做参数绑定,防止SQL注入,以后批量更新不同记录的不同字段,就用它吧!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
批量更新多条记录可以使用MySQL的`UPDATE`语句结合`CASE`和`WHEN`语句来实现。具体步骤如下: 1. 将需要更新的数据保存在一个临时表中,表结构与原表相同。 2. 使用`UPDATE`语句对原表进行批量更新,将临时表中的数据更新到原表中。 下面是一个示例代码: ```sql -- 创建临时表 CREATE TEMPORARY TABLE tmp_table ( id INT(11) NOT NULL, name VARCHAR(50) DEFAULT NULL, age INT(11) DEFAULT NULL, PRIMARY KEY (id) ); -- 向临时表中插入需要更新的数据 INSERT INTO tmp_table (id, name, age) VALUES (1, 'Tom', 20), (2, 'Jack', 25), (3, 'Mary', 30), ... ; -- 使用UPDATE语句进行批量更新 UPDATE original_table SET name = CASE WHEN id = 1 THEN 'Tom' WHEN id = 2 THEN 'Jack' WHEN id = 3 THEN 'Mary' ... END, age = CASE WHEN id = 1 THEN 20 WHEN id = 2 THEN 25 WHEN id = 3 THEN 30 ... END WHERE id IN (SELECT id FROM tmp_table); -- 删除临时表 DROP TABLE tmp_table; ``` 在上面的示例代码中,我们首先创建了一个临时表`tmp_table`来保存需要更新的数据。然后使用`INSERT INTO`语句将需要更新的数据插入到临时表中。 接着使用`UPDATE`语句对原表`original_table`进行批量更新。使用`CASE`和`WHEN`语句来实现根据每条记录的`id`更新对应的`name`和`age`字段。最后使用`WHERE`子句指定更新的记录范围,这里使用了子查询的方式将临时表中的`id`作为更新范围。 最后,我们删除临时表`tmp_table`。这样就完成了批量更新多条记录的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值