一、执行原生太SQL的PDO方式。 <div class="codetitle"><a style="CURSOR: pointer" data="11300" class="copybut" id="copybut11300" onclick="doCopy('code11300')"> 代码如下:<div class="codebody" id="code11300">$sql = "";//原生态sql语句 xx::model()->dbConnection->createCommand($sql)->execute(); 二、Active Record方式 (1)New 方式 <div class="codetitle"><a style="CURSOR: pointer" data="3014" class="copybut" id="copybut3014" onclick="doCopy('code3014')"> 代码如下:<div class="codebody" id="code3014">$post=new Post; $post->title='sample post'; $post->content='post body content'; $post->save(); (2)Criteria方式 也可以使用 $condition 指定更复杂的查询条件。 不使用字符串,我们可以让 $condition 成为一个 CDbCriteria 的实例,它允许我们指定不限于 WHERE 的条件。 <div class="codetitle"><a style="CURSOR: pointer" data="80988" class="copybut" id="copybut80988" onclick="doCopy('code80988')"> 代码如下:<div class="codebody" id="code80988">$criteria=new CDbCriteria; $criteria->select='title'; // 只选择 'title' 列 $criteria->condition='postID=:postID'; $criteria->params=array(':postID'=>10); $post=Post::model()->find($criteria); 一种替代 CDbCriteria 的方法是给 find 方法传递一个数组。 数组的键和值各自对应标准(criterion)的属性名和值,上面的例子可以重写为如下: <div class="codetitle"><a style="CURSOR: pointer" data="20508" class="copybut" id="copybut20508" onclick="doCopy('code20508')"> 代码如下:<div class="codebody" id="code20508">$post=Post::model()->find(array( 'select'=>'title', 'condition'=>'postID=:postID', 'params'=>array(':postID'=>10), )); 当一个查询条件是关于按指定的值匹配几个列时,我们可以使用 findByAttributes()。我们使 $attributes 参数是一个以列名做索引的值的数组。在一些框架中,此任务可以通过调用类似 findByNameAndTitle 的方法实现。虽然此方法看起来很诱人,但它常常引起混淆、冲突和比如列名大小写敏感的问题。 三、Query Builder 方式 <div class="codetitle"><a style="CURSOR: pointer" data="1946" class="copybut" id="copybut1946" onclick="doCopy('code1946')"> 代码如下:<div class="codebody" id="code1946">$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(); (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|