Yii操作数据库的3种方法

2020-02-20 16:00:19来源:爱站网 阅读 ()

新老客户大回馈,云服务器低至5折

Yii操作数据库,相信大家接触的并不是非常多,今天爱站技术频道小编为大家带来了Yii操作数据库的3种方法,感兴趣的朋友可以跟着爱站技术频道小编的步伐进入下文学习吧!

一、执行原生太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();

以上就是爱站技术频道小编为您介绍的Yii操作数据库的3种方法,学习的心态很重要,如果你跟别人学习,也要懂得配合别人的时间哦。


原文链接:https://js.aizhan.com/develop/php/11657.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:PHP文件管理之实现网盘及压缩包的功能操作

下一篇:php导出excel格式数据问题