yii2 查询数据库语法

 1         $query0 = ImGroupUser::find()->where(['gid'=>'56680dfc60b215d62104a4d8'])->select('user_client_id')->all();//AR
 2         $query1=ImGroupUser::findAll(['gid'=>'56680dfc60b215d62104a4d8']);//AR
 3         $query2=ImGroupUser::findBySql("select user_client_id from im_group_user where gid='56680dfc60b215d62104a4d8'")->all();//AR
 4         $query3=ImGroupUser::find()->where(['gid'=>'56680dfc60b215d62104a4d8'])->select('user_client_id')->asArray()->all();//Array
 5         $query = new yii\db\Query();
 6         $query4 = $query
 7             ->select(['user_client_id'])
 8             ->from(['im_group_user'])
 9             ->where(['gid'=>'56680dfc60b215d62104a4d8'])
10             ->all();//Array
11         $arr=[];
12         foreach($query4 as $key=>$value){
13 //            $arr[]=$value->user_client_id;
14             $arr[]=$value['user_client_id'];
15         }
16         var_dump($arr);

AR查询结果默认为AR单条数据的对象,返回AR对象,用13行取对象结果集,返回Array对象用14行取结果集 注意query4查询结果为数组对象

1  $res = ImGroupUser::updateAll(['flag'=>0],['gid'=>$gid,'flag'=>1]);

更新数据库字段值。(将表中所有gid为$gid并且 flag=1的列的flag设为0)

有的时候查询过程较为复杂,使用框架查询效率低下,可以直接使用sql查询:

1       $sql="select c_user.client_id,c_user.bapp_broker_id from c_user
2               where c_user.client_id!=''
3               and c_user.bapp_broker_id!='{$g32}'
4               and c_user.id in(select c_user_id from trade_fund_account where cust_id is not null and update_time between  date_sub(now(),interval 10 minute) and now() order by update_time desc)";
5         $res=Yii::$app->db->createCommand()->setSql($sql)->queryAll();

Yii查询sql也可以这样写

 1 $res=Yii::$app->db->createCommand($sql)->queryAll(); 

posted @ 2015-12-14 17:15  流火行者  阅读(916)  评论(0编辑  收藏  举报