当前位置: 首页 > news >正文

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

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

WHEN 3 THEN 3000

ENDWHERE id IN (1,2,3)

48304ba5e6f9fe08f3fa1abda7d326ab.png

稍安勿躁,咱们详解一下这条sql语句的意思:更新newhouse_clicks数据表中的clicks字段,当id=1时 设置值为1000,当id=2时设置值为2000,当id=3时设置值为3000

那么更新多个字段能不能做到呢?当然可以,贴代码:

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

WHEN 2 THEN 2000

WHEN 3 THEN 3000

END,

type = CASE id        WHEN 1 THEN 1

WHEN 2 THEN 6

WHEN 3 THEN 8

ENDWHERE id IN (1,2,3)

48304ba5e6f9fe08f3fa1abda7d326ab.png

这条sql语句的含义就是更新newhouse_clicks数据表中的clicks字段,当id=1是设置值为1000,当id=2时设置值为2000,当id=3时设置值为3000,更新type字段,当id=1时更新为type字段为1,当id=2时更新type字段为6,当id=3时,更新type字段为8。那么,世界上最好的语言PHP不就可以拼出来sql了吗?

48304ba5e6f9fe08f3fa1abda7d326ab.png//查询数据库返回的数据格式

$newhouse_clicks = array(

1 => 2,

2 => 3,

3 => 8,

4 => 9,

);

$ids = implode(',', array_keys($newhouse_clicks ));

$sql = "UPDATE newhouse_clicks SET clicks = CASE id ";

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

$sql .= sprintf("WHEN %d THEN %d ", $key, $value);

}

$sql .= "END WHERE id IN ($ids)";

echo $sql;

48304ba5e6f9fe08f3fa1abda7d326ab.png

大家查看一下是不是和咱们上面的sql语句是一样的呀!

那么,咱们真是的数据是不是要比这复杂呀?肯定的,看题,咱们通常在数据库里面取出来的数据格式是不是都是这样的。

48304ba5e6f9fe08f3fa1abda7d326ab.png//查询数据库返回的数据格式

$newhouse_clicks = array(     1 => array('clicks'=>1,'type'=>1,'update_time'=>time()),     2 => array('clicks'=>2,'type'=>2,'update_time'=>time()),     3 => array('clicks'=>3,'type'=>3,'update_time'=>time()),     4 => array('clicks'=>4,'type'=>4,'update_time'=>time()),

);

?>

48304ba5e6f9fe08f3fa1abda7d326ab.png

那么,这种情况怎么办?

48304ba5e6f9fe08f3fa1abda7d326ab.png<?php //查询数据库返回的数据格式$newhouse_clicks = array(    1 => array('clicks'=>1,'type'=>1,'update_time'=>time()),

2 => array('clicks'=>2,'type'=>2,'update_time'=>time()),

3 => array('clicks'=>3,'type'=>3,'update_time'=>time()),

4 => array('clicks'=>4,'type'=>4,'update_time'=>time()),);    //获取所有的id

$newhouse_clicks_keys = array_keys($newhouse_clicks);    //拼接批量更新sql语句

$sql = "UPDATE newhouse_clicks SET ";    //合成sql语句

foreach ($newhouse_clicks[1] as $key => $value) {        $sql .= "{$key} = CASE id ";        foreach ($newhouse_clicks as $newhouse_clicks_key=>$newhouse_clicks_value) {

$sql .= sprintf("WHEN %d THEN %d ", $newhouse_clicks_key, $newhouse_clicks_value[$key]);

}        $sql .= "END, ";

}    //把最后一个,去掉

$sql = substr($sql, 0, strrpos($sql,','));

//合并所有id

$ids = implode(',', $newhouse_clicks_keys);    //拼接sql

$sql .= " WHERE ID IN ({$ids})";    echo $sql;

48304ba5e6f9fe08f3fa1abda7d326ab.png

其实,写了这么一大堆,是不是就是为了拼装成mysql语句呀。

大功告成!速度是不是像丝般顺滑!

老多程序员特别是初学者,很容易进入一个误区,把在sql中取数据套在for循环里面。这样写导致一个问题,就是严重的阻塞,现实生活中就有这样一个例子:

比如说,你在12层办公,这是快递员给你打电话让你去楼下取快递(总共12件),你去取快递有两种方式:

1.拿到第一件快递,跑回12层,放好后,接着去领取下一件快递,放好12层后再接着去取下一件快递。

2.一次性把所有的快递都拿到12层。

大家一定都会选第二个方案吧,没人会傻不拉几的去跑12次才能拿完快递的。

计算机就是上述原理,在for循环里面去资源取数据,就是类似第一种方案。批量取数据就是类似于第二种方案。(PS一下:不要以为在mysql中取数据有这种问题,redis也会

有这种问题,要不然怎么会有pipeline取批量数据呢,这一点在面试的时候我是经常当面试题去问的,绝对会成为衡量一个人技术水平的标准)

相关文章:

  • [领域]javascript hacking guide 第3部分
  • mysql 获取两张表数据_PHP MySQL 获取两张表的数据,第二张表的数据等于第一张表的某个键的值...
  • 诗人2
  • echarts一个页面有多个tooltip_Echarts!再也不用担心我的数据图形了
  • mysql用root启动报错_Mysql Cluster 非root用户启动ndbd节点报错
  • 深入理解C/C++函数指针
  • spring mysql 自动重连_再淡spring jdbc 连接池断开重连设置
  • 终极恢复孰弱孰强-DUL vs AUL
  • jsp动态分页 mysql后台查询_JSP留言板系统(前台:游客增查+后台管理员:增删改查删回复+MVC+列表分页+MySQL)...
  • [领域]javascript hacking guide part 4
  • 导入csv 0的问题_解决:MySQL workbench8.0 无法导入csv
  • 多态性——vptr和vtable
  • mysql建删改查_mysql 操作数据库创建,增删改查
  • python中wraps_python装饰器函数wraps
  • 什么是期货
  • android 一些 utils
  • Angular6错误 Service: No provider for Renderer2
  • Java到底能干嘛?
  • maya建模与骨骼动画快速实现人工鱼
  • MySQL-事务管理(基础)
  • SSH 免密登录
  • 安卓应用性能调试和优化经验分享
  • 基于Dubbo+ZooKeeper的分布式服务的实现
  • 浅析微信支付:申请退款、退款回调接口、查询退款
  • 如何编写一个可升级的智能合约
  • 如何优雅的使用vue+Dcloud(Hbuild)开发混合app
  • 双管齐下,VMware的容器新战略
  • 问题之ssh中Host key verification failed的解决
  • 我这样减少了26.5M Java内存!
  • 一天一个设计模式之JS实现——适配器模式
  • 用Node EJS写一个爬虫脚本每天定时给心爱的她发一封暖心邮件
  • #【QT 5 调试软件后,发布相关:软件生成exe文件 + 文件打包】
  • #大学#套接字
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • (2009.11版)《网络管理员考试 考前冲刺预测卷及考点解析》复习重点
  • (LeetCode C++)盛最多水的容器
  • (ZT)北大教授朱青生给学生的一封信:大学,更是一个科学的保证
  • (超详细)2-YOLOV5改进-添加SimAM注意力机制
  • (翻译)Quartz官方教程——第一课:Quartz入门
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (使用vite搭建vue3项目(vite + vue3 + vue router + pinia + element plus))
  • (四)TensorRT | 基于 GPU 端的 Python 推理
  • (一)【Jmeter】JDK及Jmeter的安装部署及简单配置
  • (一)硬件制作--从零开始自制linux掌上电脑(F1C200S) <嵌入式项目>
  • (转)项目管理杂谈-我所期望的新人
  • ./mysql.server: 没有那个文件或目录_Linux下安装MySQL出现“ls: /var/lib/mysql/*.pid: 没有那个文件或目录”...
  • .Net 访问电子邮箱-LumiSoft.Net,好用
  • .net 前台table如何加一列下拉框_如何用Word编辑参考文献
  • .net快速开发框架源码分享
  • .one4-V-XXXXXXXX勒索病毒数据怎么处理|数据解密恢复
  • .vimrc php,修改home目录下的.vimrc文件,vim配置php高亮显示
  • [BUUCTF NewStarCTF 2023 公开赛道] week4 crypto/pwn
  • [C#] 基于 yield 语句的迭代器逻辑懒执行
  • [CERC2017]Cumulative Code
  • [Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated c