本文实例讲述了laravel框架批量更新数据功能。分享给大家供大家参考,具体如下:
前言
上周公司的比赛项目以泪奔结束…一台2核4g的vps完全蹦了..集体被老大叼杠。下个月的比赛又要开始了,所以现在抓紧时间升级服务器,优化代码与sql,刚看到排名那有1000多条更新语句,太受不了了,所以在google找了下资源,找到了批量更新数据的方法,记录一下。
代码
//from https://github.com/mavinoo/laravelbatchstatic function batchupdate($model, array $values, $index = null){ $final = []; $ids blow的过去式和过去分词= []; if (!count($values)) { return fal; } if会计从业资格考试题 (!ist($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' : '"' . lf::mysql_escape($val[$field]) . '"'); $final[$field][] = 'when `' . $index . '` = "' . $val[$index] . '" then ' . $value . ' '; } } } $cas = ''; foreach ($final as $k => $v) { $cas .= '`' . $k . '` = (ca ' . implode("\n", $v) . "\n" . 'el `' . $k . '` end), '; } $full_table = $model->getconnection()->gettableprefix() . $model->gettable(); $query = "update `" .$full_table . "` t " . substr($cas, 0, -2) . " where `$index` in(" . '"' . implode('","', $ids) . '"' . ");"; \db::update($query); #return $this->db->connection($this->getconnectionname($tabl南方医科大学顺德校区e))->update($query);}
测试代码如下
$urinstance = new ur();$value = [ [ 'id' => 2, 'contest_name' => 'a1', 'project_name' => 'p1' ] , [ 'id' => 3, 'contest_name' => 'a2', 'project_name' => 'p2' ] ,];$index = 'id';utils::batchupdate($us友谊英语erinstance, $value, $index);
记录完赶紧干活去….
更多关于laravel相关内容感兴趣的读者可查看本站专题:《laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于laravel框架的php程序设计有所帮助。
本文发布于:2023-04-07 08:15:15,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/2abc46bc363f8cefd682cf7c9010752a.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:Laravel框架学习笔记之批量更新数据功能.doc
本文 PDF 下载地址:Laravel框架学习笔记之批量更新数据功能.pdf
留言与评论(共有 0 条评论) |