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

YII2框架中查询生成器Query()的使用方法示例

发布:smiling 来源: PHP粉丝网  添加日期:2022-02-21 09:24:01 浏览: 评论:0 

本文实例讲述了YII2框架中查询生成器Query()的使用方法,分享给大家供大家参考,具体如下:

YII2中的yii\db\Query给我们提供了非常丰富的方法,方便我们构建复杂的SQL语句。

Query()与createCommand最大区别在于,后者直接使用我们写好的SQL语句,前者通过参数和数据库类型生成不同SQL,迁移性更好。

  1. <?php 
  2. namespace app\controllers; 
  3.    
  4. use YII; 
  5. use yii\db\Query; 
  6. use yii\web\Controller; 
  7.    
  8. class TestController extends Controller 
  9.   public function actionTest() 
  10.   { 
  11.     //YII2的Query的使用 
  12.     //Query与createCommand的区别是createCommand是直接写一个SQL来执行。 
  13.     //Query是根据参数和数据库类型生成不同的SQL,提升数据库可迁移性。 
  14.    
  15.     //通过all查询多条记录 
  16.     //我这里用tb_user表来进行演示 
  17.     $data1 = (new Query())->select(['id''name']) 
  18.       ->from('{{%user}}'
  19.       ->all(); 
  20.    
  21.     //指定where条件查询 
  22.     $data2 = (new Query())->select(['id''name']) 
  23.       ->from('{{%user}}'
  24.       ->where('id=:id', [':id' => '2']) 
  25.       ->all(); 
  26.    
  27.     //通过one查询单条记录 
  28.     $data3 = (new Query())->select(['id''name']) 
  29.       ->from('{{%user}}'
  30.       ->where('id=3'
  31.       ->one(); 
  32.    
  33.     //判断记录是否存在 
  34.     $exists = (new Query())->from('{{%user}}'
  35.       ->where('name="aaa"'
  36.       ->exists(); 
  37.    
  38.     if ($exists) { 
  39.       echo 'name=aaa 存在'
  40.     } 
  41.    
  42.     //定义字段别名 
  43.     //注意真实的字段名写后面,别名写前面 
  44.     $data4 = (new Query())->select(['ids' => 'id''names' => 'name']) 
  45.       ->from('{{%user}}'
  46.       ->where('1=1'
  47.       ->all(); 
  48.    
  49.     //通过orderby排序,和limit限制条数 
  50.     $data5 = (new Query())->select(['id''name']) 
  51.       ->from('{{%user}}'
  52.       ->where('1=1'
  53.       ->orderBy('id desc'
  54.       ->limit(3) 
  55.       ->all(); 
  56.    
  57.     //多个and条件 
  58.     //参数是数组,一个key对应一个value,默认以and拼接 
  59.     $data6 = (new Query())->select(['id''name']) 
  60.       ->from('{{%user}}'
  61.       ->where(['id' => 3, 'name' => 'aaa']) 
  62.       ->one(); 
  63.    
  64.     //in条件 
  65.     $data7 = (new Query())->select(['id''name']) 
  66.       ->from('{{%user}}'
  67.       ->where(['id' => [4, 5, 6]]) 
  68.       ->all(); 
  69.    
  70.     //或者如下方式 
  71.     $data7_2 = (new Query())->select(['id''name']) 
  72.       ->from('{{%user}}'
  73.       ->where(['in''id', [4, 5, 6]]) 
  74.       ->all(); 
  75.    
  76.     //count统计 
  77.     $count = (new Query())->from('{{%user}}')->count(); 
  78.     echo '总记录数: '$count
  79.    
  80.     //大于,大于等于,小于,小于等于where条件 
  81.     $data8 = (new Query())->select(['id''name']) 
  82.       ->from('{{%user}}'
  83.       ->where(['>=''id', 5]) 
  84.       ->all(); 
  85.    
  86.     $data9 = (new Query())->select(['id''name']) 
  87.       ->from('{{%user}}'
  88.       ->where(['<=''id', 3]) 
  89.       ->all(); 
  90.    
  91.     //like查询 
  92.     $data10 = (new Query())->select(['id''name']) 
  93.       ->from('{{%user}}'
  94.       ->where(['like''name''dd']) 
  95.       ->all(); 
  96.    
  97.     //between筛选和group by分组 
  98.     //查找出age在18到24之间的,并按sex分组 
  99.     $data11 = (new Query())->select(['id''name']) 
  100.       ->from('{{%user}}'
  101.       ->where(['between''age', 18, 24]) 
  102.       ->groupBy('sex'
  103.       ->all(); 
  104.    
  105.     //having筛选 
  106.     //按sex分组,然后统计人数大于3的 
  107.     $data12 = (new Query())->select(['sex''cnt' => 'count(*)']) 
  108.       ->from('{{%user}}'
  109.       ->groupBy('sex'
  110.       ->having('cnt > 3'
  111.       ->all(); 
  112.    
  113.     //or逻辑条件 
  114.     //查找姓名为aaa或bbb的用户 
  115.     //之前where数组是以key=>value方式传递的,如果要表达复杂逻辑关系, 
  116.     //数组第一个元素必须声明是什么逻辑,and还是or 
  117.     //第二个元素表示逻辑左边 
  118.     //第三个元素表示逻辑右边 
  119.     $data13 = (new Query())->select(['id''name']) 
  120.       ->from('{{%user}}'
  121.       ->where(['or', ['name' => 'aaa'], ['name' => 'bbb']]) 
  122.       ->all(); 
  123.    
  124.     //复杂的where条件 
  125.     //我这里只是作为演示 
  126.     //SELECT `id`, `name` FROM `tb_user` WHERE ((`name`='aaa') OR (`name`='bbb')) OR ((`name`='ccc') OR (`name`='ddd')) 
  127.     $data14 = (new Query())->select(['id''name']) 
  128.       ->from('{{%user}}'
  129.       ->where([ 
  130.         'or'
  131.         [ 
  132.           'or'
  133.           ['name' => 'aaa'], 
  134.           ['name' => 'bbb'], 
  135.         ], 
  136.         [ 
  137.           'or'
  138.           ['name' => 'ccc'], 
  139.           ['name' => 'ddd'], 
  140.         ], 
  141.       ]) 
  142.       ->all(); 
  143.    
  144.     //and和or嵌套where条件 
  145.     //SELECT `id`, `name` FROM `tb_user` WHERE (`sex`=1) AND ((`name` LIKE '%aa%') OR (`name` LIKE '%bb%')) 
  146.     $data15 = (new Query())->select(['id''name']) 
  147.       ->from('{{%user}}'
  148.       ->where([ 
  149.         'and'
  150.         ['sex' => 1], 
  151.         [ 
  152.           'or'
  153.           ['like''name''aa'], 
  154.           ['like''name''bb'], 
  155.         ], 
  156.       ]) 
  157.       ->all(); 
  158.    
  159.     //有些时候我们需要根据用户传递过来的参数追加where条件 
  160.     //追加and条件 
  161.     $query = (new Query())->select(['id''name']) 
  162.       ->from('{{%user}}'
  163.       ->where('sex=1'); 
  164.     //追加age大于18的条件 
  165.     $query->andWhere(['>''age', 18]); 
  166.     echo $query->createCommand()->getRawSql(); 
  167.    
  168.     //追加or条件 
  169.     $query2 = (new Query())->select(['id''name']) 
  170.       ->from('{{%user}}'
  171.       ->where(['like''name''aa']); 
  172.     //追加name相似bb的条件 
  173.     $query2->orWhere(['like''name''bb']); 
  174.     echo $query2->createCommand()->getRawSql(); 
  175.    
  176.     //表别名和连接查询 
  177.     //SELECT `u`.`id`, `u`.`name`, `aa`.`item_name` FROM `tb_user` `u` LEFT JOIN `tb_auth_assignment` `aa` ON aa.user_id = u.id 
  178.     $data16 = (new Query())->select(['u.id''u.name''aa.item_name']) 
  179.       ->from(['u' => '{{%user}}']) 
  180.       ->leftJoin(['aa' => '{{%auth_assignment}}'], 'aa.user_id = u.id'
  181.       ->all(); 
  182.   } 
  183. }

Tags: YII2查询生成器 Query

分享到: