首页 > 后端开发 > php教程 > Yii2增删改查之查询 where参数详细介绍

Yii2增删改查之查询 where参数详细介绍

高洛峰
发布: 2023-03-05 07:54:01
原创
1244 人浏览过

概述

由于官方手册关于where的介绍比较少,所以想自己整理一下,以便大家的学习和自己回头查询。本篇文章会详细介绍and、or、between、in、like在where方法中的使用方法和举例。

and

// 我们要查询id大于1并且小于3的数据
$userInfo = User::find()->where([&#39;and&#39; , &#39;id > 1&#39; , &#39;id < 3&#39;])->all();
// 或者用以下方式,更为安全
$userInfo = User::find()->where([&#39;and&#39; , [&#39;>&#39; , &#39;id&#39; , 1] , [&#39;<&#39; , &#39;id&#39; , 3]])->all();
// 往往我们会处理比这更复杂的sql
// 假如我们要查询name是王五 并且 id大于1或者id小于3的数据
$userInfo = User::find()->where(
[&#39;and&#39; ,
[&#39;=&#39; , &#39;name&#39; , &#39;王五&#39;] ,
[&#39;or&#39; ,
[&#39;=&#39; , &#39;id&#39; , 1] ,
[&#39;=&#39; , &#39;id&#39; , 3]
]
])->asArray()->all();
// 注:asArray()方法会将数据以数组的方式显示
登录后复制

or

// 我们要查询id等于1或者id等于3的数据
$userInfo = User::find()->where([&#39;or&#39; , &#39;id = 1&#39; , &#39;id = 3&#39;])->all();
// 我们同样可以使用以下方式
$userInfo = User::find()->where([&#39;or&#39; , [&#39;=&#39; , &#39;id&#39; , 1] , [&#39;=&#39; , &#39;id&#39; , 3]])->all();
// 假如我们要查询id在4,8,9范围内 或者 id在1,2,3范围内呢?
$userInfo = User::find()->where([&#39;or&#39; , [&#39;id&#39; => [4,8,9]] , [&#39;id&#39; => [1,2,3]]])->all();
登录后复制

between

// 我们要查询id在1到10的范围之内
$userInfo = User::find()->where([&#39;between&#39; , &#39;id&#39; , 1 , 10])->all();
登录后复制

in

// 我们要查询id在1、2、3的范围内
$userInfo = User::find()->where([&#39;in&#39; , &#39;id&#39; , [1,2,3]])->all();
登录后复制

like

// 我们要查询name中包含“张”这个字符的数据
$userInfo = User::find()->where([&#39;like&#39; , &#39;name&#39; , &#39;张&#39;])->all();
// 我们假如要通配name中包含“张”这个字符,而且还得包含“三”这个字符
$userInfo = User::find()->where([&#39;like&#39; , &#39;name&#39; , [&#39;张&#39; , &#39;三&#39;]])->all();
// 我们假如只需要通配左边即可
$userInfo = User::find()->where([&#39;like&#39; , &#39;name&#39; , &#39;%三&#39; , false])->all();
// 所以,右边也是同样
登录后复制

以上所述是小编给大家介绍的Yii2增删改查之查询 where参数详细介绍的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对PHP中文网的支持!

更多Yii2增删改查之查询 where参数详细介绍相关文章请关注PHP中文网!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板