php mysql 更新多条数据_PHP 一条命令update批量更新MYSQL中的数据

本文介绍了如何使用PHP和MySQL进行批量数据更新,避免使用循环更新的效率问题。通过案例展示了如何使用CASE语句和IN操作符来实现一条SQL命令更新多条记录,提高性能。
摘要由CSDN通过智能技术生成

php一条mysql update命令批量修改更新数据,免去一条条UPDATE循环修改的麻烦。

最近项目需要用到批量更新数据库里的数据,在网上找了一下这方面的例子,觉得这个还不错,分享给大家。

在这个业务里里面涉及到了更新两张数据表,那么大家是不是会想到非常简单,马上上代码

$sql = "update newhouse_clicks set clicks=6,type=1,update_time=time() where is=$value['id']";

其中数据表名为newhouse_clicks,有四个字段,主键id,type(类型-整型)字段,clicks(点击量-整型)字段,update_time(整型)字段这样做确实没有问题吗?比如说批量更新当前城市下的所有楼盘,比如说北京,打个比方1000条数据,那么在业务里面是不是就要这样写

$data = array(id=>1,id=>2,..........id=>1000);//省略数据

foreach($data as $key=>$value) {

$sql = "update newhouse_clicks set clicks=6,type=1,update_time=time() where is=$value['id']";

}

这样在涉及到多张表*1000条数据,那么会不会有很大的延时呢?

结果是的,她这样写确实是导致了服务器的超时!

大家如果熟悉JAVA等语言应该知道,JAVA会内部提供了批量更新sql的功能,那么作为世界上做好的语言PHP能不能做到呢?答案是可以滴!

那么我们学习一下批量更新的sql语句。

48304ba5e6f9fe08f3fa1abda7d326ab.pngUPDATE newhouse_clicks    SET clicks = CASE id        WHEN 1 THEN 1000

WHEN 2 THEN 2000

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值