网站首页 > 开源技术 正文
批量插入数据在优化数据库连接时很有作用,特别是在数据量很大情况下,可以减少数据库连接,所以此方法大家都应该掌握。
批量插入我们使用 batchInsert ,至于具体用法大家可以看文档,不看文档也没关系,相信大家直接看例子也能明白。
批量插入的例子
//要插入地表的名称
$tableName = Post::tableName();
//要插入的字段
$field = [‘id’,’name’];
//要插入的数据(注:是一个二维数组)
$insertData[] = [1,”PHP学习网”];
$insertData[] = [2,”PHP学习网”];
$insertData[] = [3,”PHP学习网”];
$insertData[] = [4,”PHP学习网”];
$insertData[] = [5,”PHP学习网”];
$insertData[] = [6,”PHP学习网”];
//执行,返回值为插入成功的数目
$totalnum = Yii::$app->db->createCommand()->batchInsert($tableName,$field,$insertData)->execute();
以上是没有经过数据合法效验的,若是需要效验请使用
$rows = [];
foreach ($insertData as $model) {
if (!$model->validate()) {
// 处理无效数据
break;
}
$rows[] = $model->attributes;
}
$totalnum = Yii::$app->db->createCommand()->batchInsert($tableName,$field,$rows)->execute();
若是效验确实不需要,也可以使用,下面的方法简化效验
use yii\helpers\ArrayHelper;
$rows = ArrayHelper::getColumn($insertData, ‘attributes’);
接下来执行
$post = new Post();
Yii::$app->db->createCommand()->batchInsert(Post::tableName(), $post->attributes(), $rows)->execute();
至于是哪种还需要开发过程中灵活使用,选择合适自己的。
猜你喜欢
- 2024-09-11 少年歌行。第2部。萧崇登基后……
- 2024-09-11 少年歌行2:司空千落怀孕,萧瑟居然要娶别人为妻
- 2024-09-11 YII框架学习(新手)NO.2(yii框架设计模式)
- 2024-09-11 yii安装与使用详解(easy_install安装)
- 2024-09-11 小编教你 YII2框架模块如何绑定二级域名
- 2024-09-11 一款基于Yii2+Vue2.0+uniapp的开源商城
- 2024-09-11 Yii2开发中js冲突 如何禁用自带的 yii、jquery 和 bootstrap
- 2024-09-11 一款基于Yii2开发的免费商城系统(开发一款游戏的步骤)
- 2024-09-11 Yii2连接pgsql,设置默认schema(sqlplus默认连库)
- 2024-09-11 php生命周期、Laravel生命周期、Yii2生命周期、ThinkPHP生命周期
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)