zoukankan      html  css  js  c++  java
  • 批量更新数据问题

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

    主要代码如下(简写):

    <?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");
  • 相关阅读:
    小程序实现无限瀑布流
    Vue H5 项目模板
    Taro使用mobx做国际化小程序
    一次国际化记录以及平铺JSON数据
    Promise(interesting)
    返回状态码
    CSS属性兼容写法
    在DOM加载之前insertScript
    关于吸烟
    前端优化措施
  • 原文地址:https://www.cnblogs.com/lizhaoyao/p/7472923.html
Copyright © 2011-2022 走看看