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语句。
UPDATE newhouse_clicks SET clicks = CASE id WHEN 1 THEN 1000
WHEN 2 THEN 2000