Laravel框架学习笔记之批量更新数据功能
程序员文章站
2022-03-20 13:50:50
本文实例讲述了laravel框架批量更新数据功能。分享给大家供大家参考,具体如下:
前言
上周公司的比赛项目以泪奔结束...一台2核4g的vps完全蹦了..集体被老大叼...
本文实例讲述了laravel框架批量更新数据功能。分享给大家供大家参考,具体如下:
前言
上周公司的比赛项目以泪奔结束...一台2核4g的vps完全蹦了..集体被老大叼杠。下个月的比赛又要开始了,所以现在抓紧时间升级服务器,优化代码与sql,刚看到排名那有1000多条更新语句,太受不了了,所以在google找了下资源,找到了批量更新数据的方法,记录一下。
代码
//from https://github.com/mavinoo/laravelbatch static function batchupdate($model, array $values, $index = null){ $final = []; $ids = []; if (!count($values)) { return false; } if (!isset($index) || empty($index)) { $index = $model->getkeyname(); } foreach ($values as $key => $val) { $ids[] = $val[$index]; foreach (array_keys($val) as $field) { if ($field !== $index) { $value = (is_null($val[$field]) ? 'null' : '"' . self::mysql_escape($val[$field]) . '"'); $final[$field][] = 'when `' . $index . '` = "' . $val[$index] . '" then ' . $value . ' '; } } } $cases = ''; foreach ($final as $k => $v) { $cases .= '`' . $k . '` = (case ' . implode("\n", $v) . "\n" . 'else `' . $k . '` end), '; } $full_table = $model->getconnection()->gettableprefix() . $model->gettable(); $query = "update `" .$full_table . "` set " . substr($cases, 0, -2) . " where `$index` in(" . '"' . implode('","', $ids) . '"' . ");"; \db::update($query); #return $this->db->connection($this->getconnectionname($table))->update($query); }
测试代码如下
$userinstance = new user(); $value = [ [ 'id' => 2, 'contest_name' => 'a1', 'project_name' => 'p1' ] , [ 'id' => 3, 'contest_name' => 'a2', 'project_name' => 'p2' ] , ]; $index = 'id'; utils::batchupdate($userinstance, $value, $index);
记录完赶紧干活去....
更多关于laravel相关内容感兴趣的读者可查看本站专题:《laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于laravel框架的php程序设计有所帮助。
推荐阅读
-
Python ORM框架SQLAlchemy学习笔记之数据查询实例
-
Python ORM框架SQLAlchemy学习笔记之数据添加和事务回滚介绍
-
laravel框架学习笔记之组件化开发实现方法
-
Laravel框架学习笔记(二)项目实战之模型(Models)
-
Laravel 5框架学习之数据库迁移(Migrations)
-
Laravel 5框架学习之向视图传送数据
-
Laravel 5框架学习之向视图传送数据(进阶篇)
-
荐 从零写一个具有IOC-AOP-MVC功能的框架---学习笔记---11. MVC功能之http请求处理器的编写---简易框架最后一公里!
-
Laravel框架学习笔记之批量更新数据功能
-
Laravel 5框架学习之向视图传送数据(进阶篇)_php实例