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

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

<?php

namespace app\controllers;

use YII;
use yii\db\Query;
use yii\web\Controller; class TestController extends Controller
{
public function actionTest()
{
//YII2的Query的使用
//Query与createCommand的区别是createCommand是直接写一个SQL来执行。
//Query是根据参数和数据库类型生成不同的SQL,提升数据库可迁移性。 //通过all查询多条记录
//我这里用tb_user表来进行演示
$data1 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->all(); //指定where条件查询
$data2 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where('id=:id', [':id' => '2'])
->all(); //通过one查询单条记录
$data3 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where('id=3')
->one(); //判断记录是否存在
$exists = (new Query())->from('{{%user}}')
->where('name="aaa"')
->exists(); if ($exists) {
echo 'name=aaa 存在';
} //定义字段别名
//注意真实的字段名写后面,别名写前面
$data4 = (new Query())->select(['ids' => 'id', 'names' => 'name'])
->from('{{%user}}')
->where('1=1')
->all(); //通过orderby排序,和limit限制条数
$data5 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where('1=1')
->orderBy('id desc')
->limit(3)
->all(); //多个and条件
//参数是数组,一个key对应一个value,默认以and拼接
$data6 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['id' => 3, 'name' => 'aaa'])
->one(); //in条件
$data7 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['id' => [4, 5, 6]])
->all(); //或者如下方式
$data7_2 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['in', 'id', [4, 5, 6]])
->all(); //count统计
$count = (new Query())->from('{{%user}}')->count();
echo '总记录数: ', $count; //大于,大于等于,小于,小于等于where条件
$data8 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['>=', 'id', 5])
->all(); $data9 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['<=', 'id', 3])
->all(); //like查询
$data10 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['like', 'name', 'dd'])
->all(); //between筛选和group by分组
//查找出age在18到24之间的,并按sex分组
$data11 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['between', 'age', 18, 24])
->groupBy('sex')
->all(); //having筛选
//按sex分组,然后统计人数大于3的
$data12 = (new Query())->select(['sex', 'cnt' => 'count(*)'])
->from('{{%user}}')
->groupBy('sex')
->having('cnt > 3')
->all(); //or逻辑条件
//查找姓名为aaa或bbb的用户
//之前where数组是以key=>value方式传递的,如果要表达复杂逻辑关系,
//数组第一个元素必须声明是什么逻辑,and还是or
//第二个元素表示逻辑左边
//第三个元素表示逻辑右边
$data13 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['or', ['name' => 'aaa'], ['name' => 'bbb']])
->all(); //复杂的where条件
//我这里只是作为演示
//SELECT `id`, `name` FROM `tb_user` WHERE ((`name`='aaa') OR (`name`='bbb')) OR ((`name`='ccc') OR (`name`='ddd'))
$data14 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where([
'or',
[
'or',
['name' => 'aaa'],
['name' => 'bbb'],
],
[
'or',
['name' => 'ccc'],
['name' => 'ddd'],
],
])
->all(); //and和or嵌套where条件
//SELECT `id`, `name` FROM `tb_user` WHERE (`sex`=1) AND ((`name` LIKE '%aa%') OR (`name` LIKE '%bb%'))
$data15 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where([
'and',
['sex' => 1],
[
'or',
['like', 'name', 'aa'],
['like', 'name', 'bb'],
],
])
->all(); //有些时候我们需要根据用户传递过来的参数追加where条件
//追加and条件
$query = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where('sex=1');
//追加age大于18的条件
$query->andWhere(['>', 'age', 18]);
echo $query->createCommand()->getRawSql(); //追加or条件
$query2 = (new Query())->select(['id', 'name'])
->from('{{%user}}')
->where(['like', 'name', 'aa']);
//追加name相似bb的条件
$query2->orWhere(['like', 'name', 'bb']);
echo $query2->createCommand()->getRawSql(); //表别名和连接查询
//SELECT `u`.`id`, `u`.`name`, `aa`.`item_name` FROM `tb_user` `u` LEFT JOIN `tb_auth_assignment` `aa` ON aa.user_id = u.id
$data16 = (new Query())->select(['u.id', 'u.name', 'aa.item_name'])
->from(['u' => '{{%user}}'])
->leftJoin(['aa' => '{{%auth_assignment}}'], 'aa.user_id = u.id')
->all();
}
}

  

YII2中查询生成器Query()的使用的更多相关文章

  1. Yii的学习(3)--查询生成器 (Query Builder)

    原文地址:http://www.yiiframework.com/doc/guide/1.1/en/database.query-builder 不过原文是英文的,Yii的官网没有翻译这一章,自己就尝 ...

  2. MongoDB官方C#驱动中查询条件Query用法

    Query.All("name", "a", "b");//通过多个元素来匹配数组 Query.And(Query.EQ("nam ...

  3. Yii2中多表关联查询(join、joinwith)

    我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order      (id  order_name ...

  4. [moka同学笔记]Yii2中多表关联查询(join、joinwith) (摘录)

    表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order          (id  order_name       cu ...

  5. Yii2.0中文开发向导——Yii2中多表关联查询(join、joinwith)(转)

    我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order          (id  order_ ...

  6. Yii2.0中文开发向导——Yii2中多表关联查询(join、joinwith)

    我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order          (id  order_ ...

  7. Yii2中多表关联查询(hasOne、hasMany、join、joinwith)

    表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order      (id  order_name  customer_id ...

  8. Yii2中多表关联查询(with、join、joinwith)

    表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer   (id  customer_name) 订单表Order         (id  order_name   custome ...

  9. mongoose中的流查询stream query

    mongoose中的流查询stream query,功能类似于php中的mysql_fetch_array,每次从集合中获取一条记录(文档) var cursor = Person.find({ oc ...

随机推荐

  1. suse 奇怪的crash 问题

    最近遇到一个suse的crash 问题: 我没有使用 mkswap /dev/磁盘路径 来制作swap分区,我有很多剩余内存,我设置nr_swapfiles为0,可是我还是遇到了关于swap的cras ...

  2. Mastering Creativity:A brief guide on how to overcome creative blocks

    MASTERING CREATIVITY, 1st EditionThis guide is free and you are welcome to share it withothers.From ...

  3. LINUX系统一一常用命令

    前言 LINUX UNIX Centos RedHat Ubuntu SHELL shell脚本 shell shell命令 类似windows系统的bat 批处理文件 里面都是脚本 CentOS6. ...

  4. (转) 为什么选择.NETCore?

    https://www.cnblogs.com/xiaoliangge/p/8373100.html 为什么选择.NETCore?    为什么选择.NETCore? 学习新的开发框架是一项巨大的投资 ...

  5. /src/log4j2.xml

    <?xml version="1.0" encoding="UTF-8"?> <Configuration status="warn ...

  6. 本地Navicat连不上Linux虚拟机MySQL数据库问题

    LinuxAndMySQL 版权声明:本文为博主原创文章,未经博主允许不得转载. 在Linux登录到MySQL数据:mysql -uroot -p 输入密码 切换到mysql数据库 mysql> ...

  7. 常见三种字符编码的区别:ASCII、Unicode、UTF-8

    什么是字符编码? 计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理.最早的计算机在设计时采用8个比特(bit)作为一个字节(byte),所以,一个字节能表示的最大的整数就是255( ...

  8. pip 离线安装

    pip download ansible -d . --trusted-host mirrors.aliyun.com pip install ansible-2.7.5.tar.gz  --user ...

  9. Ubuntu下面的docker开启ssh服务

    选择主流的openssh-server作为服务端: root@161f67ccad50:/# apt-get install openssh-server -y Reading package lis ...

  10. 微信小程序实现滚动分页加载更多

    参考网址:https://www.cnblogs.com/Smiled/p/8203306.html 1.wxml: <view class='myScroll' style='float:le ...