您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 9595|回复: 0
打印 上一主题 下一主题

[thinkphp学习资料] where查询表达式

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
8 m/ `4 B7 R" q! F" w) T表达式        含义9 I  n) x( @  Y$ Q( m, @
EQ        等于(=)
' k7 q1 z/ F+ D2 p4 RNEQ        不等于(<>)
9 P; X8 i& o$ E3 @0 j, Z9 X" jGT        大于(>)" k9 q3 r: M4 k, G; x, L
EGT        大于等于(>=)" N  q- W' L0 S
LT        小于(<)
0 n7 R# _3 a9 W4 ~) W  N+ gELT        小于等于(<=). B: _& w' ?+ l9 v0 l) f) E% h
LIKE        模糊查询
5 G* E& o7 q! c2 P7 {0 n[NOT] BETWEEN        (不在)区间查询6 z" y% b. v- K; V+ V. v) N3 z
[NOT] IN        (不在)IN 查询
: B( R# N$ `( W7 X- f: i. TEXP        表达式查询,支持SQL语法1 K9 r( J% w/ A( y, z( r9 f( C

1 s5 [6 G* {, |& Z% c% J8 H6 K  {' W7 x* `" W8 f7 j5 t3 u0 T
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
; q3 L& \; M3 H3 |& U) P  g: K( kM("User")->where($where)->select();//查询status为0的记录
8 [" y6 ?0 Q0 N4 N  k5 k! p! j6 s
" Q( v" V3 s$ I0 i- J2 v% D0 u8 S3、where方法数组查询例子1 l" R! ]9 J2 N' s, d
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
6 i# u# X+ ?/ w' ^6 A7 I$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
$ Y, H; R3 M( b4 hM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
/ ?8 ^* o  M. X1 \7 w# N& H
5 B$ \# V# {6 L8 r9 J2、数组查询使用OR查询?比如,查询status等于0或者1的记录。% i' v9 e/ @5 Y& @2 O% M
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
( o, o7 O5 z+ }3 Y7 z$ uM("User")->where($where)->select();//查询status等于0或者1的记录6 N; @: J- \# Q6 T7 @; Y) v1 B
* A" \% u6 z3 L. A
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
+ V* ^1 W- x. t; L$where['createdate'] = array('EGT',"2016-04-20");
- O. u7 |! @% H: \1 n: Z$where['status'] = '1';
0 |  F& _9 ^& q3 H! S) [* q$condition['_logic'] = "AND";
) e8 C% q5 s" b* U  ?$map['_complex']=$where;
6 C9 q- M: x( F6 u# f, \% E% C$map['level']='0';& y7 y% Z  @+ i7 U6 m8 r
$map['_logic']='OR';5 L7 N. n: `. m. \7 ^3 o
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
. m* Q6 J2 t1 H- L
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-5-20 08:24 , Processed in 0.121838 second(s), 19 queries .

Copyright © 2001-2024 Powered by cncml! X3.2. Theme By cncml!