laravel如何实现批量更新数据?
发布时间:2022-04-14 14:04:08 所属栏目:语言 来源:互联网
导读:laravel怎样实现批量更新数据?我们知道Laravel框架中有批量插入数据的方法,但是没有批量更新的方法,如果要每条数据都执行一次,那么不仅速度慢而且会占用更多的资源。对此,这篇文章就给大家分享一下laravel实现批量更新多条数据的方法。 准备 mysql case
laravel怎样实现批量更新数据?我们知道Laravel框架中有批量插入数据的方法,但是没有批量更新的方法,如果要每条数据都执行一次,那么不仅速度慢而且会占用更多的资源。对此,这篇文章就给大家分享一下laravel实现批量更新多条数据的方法。 准备 mysql case…when的用法 MySQL 的 case when 的语法有两种: 简单函数 CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END: 枚举这个字段所有可能的值 select id,status '状态值', case status when 10 then '未开始' when 20 then '配送中' when 30 then '已完成' when 40 then '已取消' End '状态' from table 输出结果: 搜索函数 CASE WHEN [expr] THEN [result1]…ELSE [default] END CASE WHEN [expr] THEN [result1]…ELSE [default] END:搜索函数可以写判断,并且搜索函数只会返回第一个符合条件的值,其他case被忽略 select id,lessee_id '租户ID', case when lessee_id <=1 then '自用系统' when lessee_id >1 then '租用系统' End '系统分类' from waybill_base_info 即是将条件语句写在了一起。这里的where部分不影响代码的执行,但是会提高sql执行的效率。确保sql语句仅执行需要修改的行数,这里只有3条数据进行更新,而where子句确保只有3行数据执行。 更新多列的值 UPDATE base_info SET city_id = CASE id WHEN 1 THEN 100010 WHEN 2 THEN 100011 WHEN 3 THEN 100012 END, city_name = CASE id WHEN 1 THEN ‘北京' WHEN 2 THEN ‘上海' WHEN 3 THEN ‘广州' END WHERE id IN (1,2,3) 不过这个有个缺点 : 要注意的问题是SQL语句的长度,需要考虑程序运行环境所支持的字符串长度,当然这也可以更新mysql的设置来扩展。 (编辑:云计算网_泰州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |