yii操作数据库的三种方式

yii操作数据库的三种方式

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

(相关教程推荐:yii框架)

(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操作数据库的三种方式的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/96653.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月19日 23:25:12
下一篇 2025年11月20日 00:05:54

相关推荐

发表回复

登录后才能评论
关注微信