当前位置:首页 > CMS教程 > 其它CMS > 列表

Yii操作数据库的3种方法

发布:smiling 来源: PHP粉丝网  添加日期:2020-10-26 10:17:02 浏览: 评论:0 

这篇文章主要介绍了Yii操作数据库的3种方法,需要的朋友可以参考下

一、执行原生太SQL的PDO方式,代码如下:

  1. $sql = "";//原生态sql语句  
  2. xx::model()->dbConnection->createCommand($sql)->execute();  

二、Active Record方式

(1)New 方式,代码如下:

  1. $post=new Post;  
  2. $post->title='sample post';  
  3. $post->content='post body content';  
  4. $post->save();  

(2)Criteria方式

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

  1. $criteria=new CDbCriteria;  
  2. $criteria->select='title';  // 只选择 'title' 列  
  3. $criteria->condition='postID=:postID';  
  4. $criteria->params=array(':postID'=>10);  
  5. $post=Post::model()->find($criteria); 

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

  1. $post=Post::model()->find(array(  
  2.     'select'=>'title',  
  3.     'condition'=>'postID=:postID',  
  4.     'params'=>array(':postID'=>10),  
  5. )); 

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

三、Query Builder 方式,代码如下:

  1. $user = Yii::app()->db->createCommand()  
  2.     ->select('id, username, profile')  
  3.     ->from('tbl_user u')  
  4.     ->join('tbl_profile p''u.id=p.user_id')  
  5.     ->where('id=:id'array(':id'=>$id))  
  6.     ->queryRow(); 

Tags: Yii操作数据库

分享到: