Yii2中的Active Record可以批量插入数据吗

Yii2中的Active Record可以批量插入数据吗,第1张

批量添加这个 *** 作,在实际开发中经常用得到,今天小编抽空给大家整理些有关yii2批量添加的问题,感兴趣的朋友一起看看吧。 在上篇文章给大家介绍了关于浅析Yii2 gridview实现批量删除教程,当然,着重点在于怎么去 *** 作gridview了,今儿我们来好好谈谈yii2如何批量添加数据? 有同学嚷嚷了,这还不简单,我foreach一循环,每个循环里面直接把数据插入到数据库,简单粗暴完事!我擦嘞,哥,你要是跟我在一个公司,我觉得第二天见到你的概率可就不大了! 话不多说,说多了你在骂我,我们步入正题,先看一个简单到小学生都认识的表结构 //test id name我们现在就是要在yii2中对这张数据表批量插入10条数据 我们想要的方式肯定是下面这样的,一条sql多么干脆直接了事 insert into test (name) values ('zhangsan'), ('lisi') 分析都分析完了,好吧,赶紧看看具体实现 //假如 $names = ['zhangsan', 'lisi'] $data = [] foreach ($names $k =>$v) { $data[] = [$v] } Yii::$app->db->createCommand()->batchInsert('test', ['name'], $data)->execute() 我相信很多人都是冲着AR能不能实现批量插入来的,理由无非就是更安全更方便 *** 作呗。但是官方手册貌似没有,没有,没有。。。心都碎了,竟然没有,至少我没有找到,你找到了请点击原文找到我并联系我,我也si分的需要方法啊。 不过不巧的是,我找到一个跟AR相关联的 *** 作方法,我们共同分享参考一下看看具体怎么回事 假设有一个Post类的数组 $models,你就可以这样 *** 作 use yii\helpers\ArrayHelper $rows = [] foreach ($models as $model) { if ($model->validate()) { $rows[] = $model->attributes } } $rows = ArrayHelper::getColumn($models, 'attributes') $postModel = new Post Yii::$app->db->createCommand()->batchInsert(Post::tableName(), $postModel->attributes(), $rows)->execute() //当然啦,上面给出的是插入所有的字段,但事实往往事与愿违,也简单,稍作调整即可 $rows[] = [ 'title' =>$model->title, 'content' =>$model->content, ] Yii::$app->db->createCommand()->batchInsert(Post::tableName(), ['title', 'content'], $rows)->execute() 虽然又回到了batchInsert上,不过没关系,该验证的都验证了,安全是无须担心的。 以上所述是小编给大家介绍的Yii2如何批量添加数据的相关知识,希望对大家有所帮助!

在配置文件设置属性:webb/config/main.php中添加persistent或者attributes属性;

检测是否成功启用长连接

可以调用frameworkdbCDbConnection.php下的getPersistent()函数,返回true为启用成功,false为启用失败;

如果使用了长连接而长期没有对数据库进行任何 *** 作,那么在timeout值后,mysql

server就会关闭此连接,而客户端在执行查询的时候就会得到一个类似于“MySQL server has gone away“这样的错误。

望采纳,谢谢!

一、执行原生太SQL的PDO方式。搜索

复制代码代码如下:

$sql = ""//原生态sql语句

xx::model()->dbConnection->createCommand($sql)->execute()

二、Active Record方式

(1)New 方式

复制代码代码如下:

$post=new Post

$post->title='sample post'

$post->content='post body content'

$post->save()

(2)Criteria方式

也可以使用 $condition 指定更复杂的查询条件。 不使用字符串,我们可以让 $condition 成为一个 CDbCriteria 的实例,它允许我们指定不限于 WHERE 的条件。

复制代码代码如下:

$criteria=new CDbCriteria

$criteria->select='title'// 只选择 'title' 列

$criteria->condition='postID=:postID'

$criteria->params=array(':postID'=>10)

$post=Post::model()->find($criteria)

一种替代 CDbCriteria 的方法是给 find 方法传递一个数组。 数组的键和值各自对应标准(criterion)的属性名和值,上面的例子可以重写为如下:

复制代码代码如下:

$post=Post::model()->find(array(

'select'=>'title',

'condition'=>'postID=:postID',

'params'=>array(':postID'=>10),

))

当一个查询条件是关于按指定的值匹配几个列时,我们可以使用 findByAttributes()。我们使 $attributes 参数是一个以列名做索引的值的数组。在一些框架中,此任务可以通过调用类似 findByNameAndTitle 的方法实现。虽然此方法看起来很诱人,但它常常引起混淆、冲突和比如列名大小写敏感的问题。

三、Query Builder 方式

复制代码代码如下:

$user = Yii::app()->db->createCommand()

->select('id, username, profile')

->from('tbl_user u')

->join('tbl_profile p', 'u.id=p.user_id')

->where('id=:id', array(':id'=>$id))

->queryRow()


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9940506.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存