Yii框架where查询用法实例分析

 更新时间:2019年10月22日 11:32:46   作者:阿朗999  
这篇文章主要介绍了Yii框架where查询用法,结合实例形式分析了Yii框架查询中where的相关使用技巧与操作注意事项,需要的朋友可以参考下

本文实例讲述了Yii框架where查询用法。分享给大家供大家参考,具体如下:

1.简述

Yii的查询操作找使用where用的很多 总结下常用的哈希格式与操作符格式

2.操作符格式

适用于操作符的

[操作符, 操作数1, 操作数2, ...]

[ 'LIKE','nickname','%'.strtr($mix_kw,['%'=>'\%', '_'=>'\_', '\\'=>'\\\\']).'%', false ];

  • and:操作数会被 AND 关键字串联起来。例如,['and', 'id=1', 'id=2'] 将会生成 id=1 AND id=2。如果操作数是一个数组,它也会按上述规则转换成 字符串。例如,['and', 'type=1', ['or', 'id=1', 'id=2']] 将会生成 type=1 AND (id=1 OR id=2)。 这个方法不会自动加引号或者转义。
  • or:用法和 and 操作符类似,这里就不再赘述。
  • not:只需要操作数 1,它将包含在 NOT() 中。例如,['not','id = 1'] 将生成 ['not', 'id=1']。操作数 1 也可以是个描述多个表达式的数组。例如 ['not', ['status' => 'draft', 'name' =>'example']] 将生成 NOT ((status='draft') AND (name='example'))。
  • between:第一个操作数为字段名称,第二个和第三个操作数代表的是这个字段 的取值范围。例如,

['between', 'id', 1, 10] 将会生成 id BETWEEN 1 AND 10。 如果你需要建立一个值在两列之间的查询条件(比如 11 BETWEEN min_id AND max_id), 你应该使用 BetweenColumnsCondition。 请参阅 条件-对象格式 一章以了解有关条件的对象定义的更多信息。

  • not between:与 between 类似,除了 BETWEEN 被 NOT BETWEEN 替换 在生成条件时。

in:第一个操作数应为字段名称或者 DB 表达式。第二个操作符既可以是一个数组, 也可以是一个 Query 对象。它会转换成IN 条件语句。如果第二个操作数是一个 数组,那么它代表的是字段或 DB 表达式的取值范围。如果第二个操作数是 Query 对象,那么这个子查询的结果集将会作为第一个操作符的字段或者 DB 表达式的取值范围。 例如, ['in', 'id', [1, 2, 3]] 将生成 id IN (1, 2, 3)。 该方法将正确地为字段名加引号以及为取值范围转义。in 操作符还支持组合字段,此时, 操作数1应该是一个字段名数组,而操作数2应该是一个数组或者 Query 对象, 代表这些字段的取值范围。

  • not in:用法和 in 操作符类似,这里就不再赘述。
  • like:

第一个操作数应为一个字段名称或 DB 表达式,

第二个操作数可以使字符串或数组, 代表第一个操作数需要模糊查询的值。比如,['like', 'name','tester'] 会生成 name LIKE '%tester%'。如果范围值是一个数组,那么将会生成用 AND 串联起来的 多个 like 语句。例如,['like', 'name', ['test', 'sample']] 将会生成 name LIKE '%test%' AND name LIKE '%sample%'。

第三个可选的操作数来指定应该如何转义数值当中的特殊字符。 该操作数是一个从需要被转义的特殊字符到转义副本的数组映射。 如果没有提供这个操作数,将会使用默认的转义映射。如果需要禁用转义的功能, 只需要将参数设置为 false 或者传入一个空数组即可。需要注意的是, 当使用转义映射(又或者没有提供第三个操作数的时候),第二个操作数的值的前后 将会被加上百分号。

  • or like:用法和 like 操作符类似,区别在于当第二个操作数为数组时, 会使用 OR 来串联多个 LIKE 条件语句。
  • not like:用法和 like 操作符类似,区别在于会使用 NOT LIKE 来生成条件语句。
  • or not like:用法和 not like 操作符类似,区别在于会使用 OR 来串联多个 NOT LIKE 条件语句。
  • exists:需要一个操作数,该操作数必须是代表子查询 yii\db\Query 的一个实例, 它将会构建一个 EXISTS (sub-query) 表达式。
  • not exists:用法和 exists 操作符类似,它将创建一个 NOT EXISTS (sub-query) 表达式。

>,<= 或者其他包含两个操作数的合法 DB 操作符:第一个操作数必须为字段的名称, 而第二个操作数则应为一个值。例如,['>', 'age', 10] 将会生成 age>10。

3.哈希格式

适用于简单的查询的

它是以数组的形式来书写的,数组的键表示字段的名称,而数组的值则表示 这个字段需要匹配的值。例如:

// ...WHERE (`status` = 10) AND (`type` IS NULL) AND (`id` IN (4, 8, 15))
$query->where([
  'status' => 10,
  'type' => null,
  'id' => [4, 8, 15],
]);

4.附加条件

你可以使用 andWhere() 或者 orWhere() 在原有条件的基础上 附加额外的条件

5.过滤条件

当 WHERE 条件来自于用户的输入时,你通常需要忽略用户输入的空值。 例如,在一个可以通过用户名或者邮箱搜索的表单当中,用户名或者邮箱 输入框没有输入任何东西,这种情况下你想要忽略掉对应的搜索条件, 那么你就可以使用 filterWhere() 方法来实现这个目的:

// $username 和 $email 来自于用户的输入
$query->filterWhere([
  'username' => $username,
  'email' => $email,
]);

filterWhere() 和 where() 唯一的不同就在于,前者 将忽略在条件当中的hash format的空值。所以如果$email 为空而 $username 不为空,那么上面的代码最终将生产如下 SQL ...WHERE username=:username。

提示: 当一个值为 null、空数组、空字符串或者一个只包含空格的字符串时,那么它将被判定为空值。

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

相关文章

  • ThinkPHP 连接Oracle数据库的详细教程[全]

    ThinkPHP 连接Oracle数据库的详细教程[全]

    最近收集了一些关于THinkPHP连接Oracle数据库的问题,有很多朋友按照连接mysql的方法来操作,导致有一些方法在Oreale中无法正常使用
    2012-07-07
  • 浅析PHP中strlen和mb_strlen的区别

    浅析PHP中strlen和mb_strlen的区别

    在php中常见的计算字符串长度的函数有:strlen和mb_strlen.当字符全是英文字符的时候,两者是一样。这里主要比较一下,中英文混排的时候,两个计算结果。
    2014-08-08
  • php两种无限分类方法实例

    php两种无限分类方法实例

    这篇文章主要介绍了php两种无限分类方法实例,本文给出了递归方法和非递归方法实现的无限分类实例,需要的朋友可以参考下
    2015-04-04
  • php源码之将图片转化为data/base64数据流实例详解

    php源码之将图片转化为data/base64数据流实例详解

    在网站开发中,我们可以看到有的网站将图片转化为base64数据流,这样做的好处有两点,一是减少服务器http请求,二是可以将图片作为字符串存储在数据库中,即图片可以直接从数据库中读取,那么php如何将图片转化为data/base64字符串呢?,需要的朋友可以参考下
    2016-11-11
  • Laravel 5.4向IoC容器中添加自定义类的方法示例

    Laravel 5.4向IoC容器中添加自定义类的方法示例

    Laravel这个框架,用起来方便,理解起来不简单。为什么不简单?因为包含了一大堆所谓“先进”的概念,其中依赖注入(DI)和Ioc容器是比较核心的内容之一。下面这篇文章主要给大家介绍了关于Laravel 5.4向IoC容器中添加自定义类的相关资料,需要的朋友可以参考下。
    2017-08-08
  • 用 Composer构建自己的 PHP 框架之基础准备

    用 Composer构建自己的 PHP 框架之基础准备

    这篇文章主要介绍了用 Composer构建自己的 PHP 框架的基础准备工作,其实就是各种基础知识,想自己搭建php框架的童鞋可要看仔细了
    2014-10-10
  • Yii2的XSS攻击防范策略分析

    Yii2的XSS攻击防范策略分析

    这篇文章主要介绍了Yii2的XSS攻击防范策略,较为详细的分析了XSS攻击的原理及Yii2相应的防范策略,需要的朋友可以参考下
    2016-08-08
  • 利用php-cli和任务计划实现订单同步功能的方法

    利用php-cli和任务计划实现订单同步功能的方法

    下面小编就为大家带来一篇利用php-cli和任务计划实现订单同步功能的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • PHP生成随机密码类分享

    PHP生成随机密码类分享

    这篇文章主要介绍了PHP生成随机密码类分享,生成的密码包含大小写英文字母及数字,需要的朋友可以参考下
    2014-06-06
  • layui框架实现文件上传及TP3.2.3(thinkPHP)对上传文件进行后台处理操作示例

    layui框架实现文件上传及TP3.2.3(thinkPHP)对上传文件进行后台处理操作示例

    这篇文章主要介绍了layui框架实现文件上传及TP3.2.3对上传文件进行后台处理操作,结合实例形式分析了layui框架结合thinkPHP进行文件上传与处理操作相关实现技巧,需要的朋友可以参考下
    2018-05-05

最新评论