yii2使用AR类进行增删改查操作
由于官方手册关于where的介绍比较少,所以想自己整理一下,以便大家的学习和自己回头查询。本篇文章会详细介绍and、or、between、in、like在where方法中的使用方法和举例。
and
// 我们要查询id大于1并且小于3的数据
$userInfo = User::find()->where(["and" , "id > 1" , "id < 3"])->all();
// 或者用以下方式,更为安全
// 假如我们要查询name是王五 并且 id大于1或者id小于3的数据
$userInfo = User::find()->where(
["and" ,
["=" , "name" , "王五"] ,
["or" ,
["=" , "id" , 1] ,
["=" , "id" , 3]
]
])->asArray()->all();
// 注:asArray()方法会将数据以数组的方式显示
or
// 我们要查询id等于1或者id等于3的数据
$userInfo = User::find()->where(["or" , "id = 1" , "id = 3"])->all();
// 我们同样可以使用以下方式
$userInfo = User::find()->where(["or" , ["=" , "id" , 1] , ["=" , "id" , 3]])->all();
// 假如我们要查询id在4,8,9范围内 或者 id在1,2,3范围内呢?
$userInfo = User::find()->where(["or" , ["id" => [4,8,9]] , ["id" => [1,2,3]]])->all();
between
// 我们要查询id在1到10的范围之内
// 我们要查询id在1、2、3的范围内
$userInfo = User::find()->where(["in" , "id" , [1,2,3]])->all();
like
// 我们要查询name中包含“张”这个字符的数据
$userInfo = User::find()->where(["like" , "name" , "张"])->all();
// 我们假如要通配name中包含“张”这个字符,而且还得包含“三”这个字符
$userInfo = User::find()->where(["like" , "name" , ["张" , "三"]])->all();
// 我们假如只需要通配左边即可
$userInfo = User::find()->where(["like" , "name" , "%三" , false])->all();
// 所以,右边也是同样
and
// 我们要查询id大于1并且小于3的数据
$userInfo = User::find()->where(["and" , "id > 1" , "id < 3"])->all();
// 或者用以下方式,更为安全
$userInfo = User::find()->where(["and" , [">" , "id" , 1] , ["<" , "id" , 3]])->all();
$userinfo = User::find()->where(["id"=>["1","2"]])->asarray()->all();//找出user表中id等于1和2的数据
// 往往我们会处理比这更复杂的sql// 假如我们要查询name是王五 并且 id大于1或者id小于3的数据
$userInfo = User::find()->where(
["and" ,
["=" , "name" , "王五"] ,
["or" ,
["=" , "id" , 1] ,
["=" , "id" , 3]
]
])->asArray()->all();
// 注:asArray()方法会将数据以数组的方式显示
or
// 我们要查询id等于1或者id等于3的数据
$userInfo = User::find()->where(["or" , "id = 1" , "id = 3"])->all();
// 我们同样可以使用以下方式
$userInfo = User::find()->where(["or" , ["=" , "id" , 1] , ["=" , "id" , 3]])->all();
// 假如我们要查询id在4,8,9范围内 或者 id在1,2,3范围内呢?
$userInfo = User::find()->where(["or" , ["id" => [4,8,9]] , ["id" => [1,2,3]]])->all();
between
// 我们要查询id在1到10的范围之内
$userInfo = User::find()->where(["between" , "id" , 1 , 10])->all();
// 我们要查询id在1、2、3的范围内
$userInfo = User::find()->where(["in" , "id" , [1,2,3]])->all();
like
// 我们要查询name中包含“张”这个字符的数据
$userInfo = User::find()->where(["like" , "name" , "张"])->all();
// 我们假如要通配name中包含“张”这个字符,而且还得包含“三”这个字符
$userInfo = User::find()->where(["like" , "name" , ["张" , "三"]])->all();
// 我们假如只需要通配左边即可
$userInfo = User::find()->where(["like" , "name" , "%三" , false])->all();
// 所以,右边也是同样
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: yii2使用缓存
- 下一篇: yii2 批量添加数组数据