批量更新数据问题
  xaeiTka4h8LY 29天前 34 0

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

主要代码如下(简写):

<?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");
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 29天前 0

暂无评论

推荐阅读
xaeiTka4h8LY