码迷,mamicode.com
首页 > 其他好文 > 详细

批量更新数据问题

时间:2017-09-04 13:28:46      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:ima   时间   class   user   查询   logs   table   循环   简写   

同事最近遇到一个需要根据索引字段更新状态数据的需求,而这个处理逻辑是循环查询单条更新解决

主要代码如下(简写):

<?php
foreach($array as $v)
{
    query("update table set field=‘value‘ where filed2=‘$v‘");
}
?>

主体思想是循环数组,进行更新,这样的话就是要一条条的update,这样数据多了以后总感觉执行过于缓慢,会给数据库带来压力,于是我查了查资料,找到了一个批量更新

例子如下:

技术分享

这是一个简单的例子,采用 case when then end的语句完成SQL更新里面的if else

降低update执行的频次,能够做到每50条一更新 或者每 100条一更新,这样就能大幅度的降低执行时间,减少数据库的压力了。

原SQL如下:

update `test_user` set num= case `name` 
when test1 then 100
when test2 then 200
when test3 then 300
end
where name in ("test1","test2","test3");

 

批量更新数据问题

标签:ima   时间   class   user   查询   logs   table   循环   简写   

原文地址:http://www.cnblogs.com/lizhaoyao/p/7472923.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!