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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询. V- h* c& c7 B# O& k, K
表达式        含义1 o9 u/ Z" \2 E) h- y: r  [6 K
EQ        等于(=)* f- _9 ]( I4 y, |
NEQ        不等于(<>)
4 X  }4 b  F/ z+ K& LGT        大于(>)2 B; E, ~% U6 {* `5 R1 f
EGT        大于等于(>=)
7 y* i2 ]& _1 X7 DLT        小于(<)
# o5 W# I8 ]( G# O4 ^9 @' n0 G, ~ELT        小于等于(<=)$ F* f8 p8 z4 X! n: @4 Q" y; M
LIKE        模糊查询
0 F% h* g/ f2 E[NOT] BETWEEN        (不在)区间查询
$ a; V+ ]1 e3 Q% i& O0 Q  s% r[NOT] IN        (不在)IN 查询* Y* `" t* E) c* y1 {
EXP        表达式查询,支持SQL语法. N0 C6 i. B9 G+ \8 L) ~" y- w
7 S5 h. t2 n8 R# d4 h) I- G% B
* _0 R3 v  g& v
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件, ~9 S/ W: D! l# D) u
M("User")->where($where)->select();//查询status为0的记录
# D7 w5 \, s9 O$ }5 J, \
2 }1 d' E& S& t+ Q3、where方法数组查询例子
- Z& S2 P5 T) ]; ]/ i0 G! W1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。# j' ~% U- y* i/ x$ s
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
2 h( ~  q; D4 [) b5 G, R$ W9 r& mM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录  U0 k7 O) `6 l9 ^% ?( @

$ ]; B) D1 M: }/ D7 C2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
; H! \( B  F/ t- J$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件3 g* p, i* v: h8 P5 u( Q
M("User")->where($where)->select();//查询status等于0或者1的记录
  H( t2 s% z5 H6 J5 H/ n. }! E1 K# d1 t# q( w) V
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
8 }8 I; W9 _! M$where['createdate'] = array('EGT',"2016-04-20");
8 ?: n, p& R. h$where['status'] = '1';
+ D8 e! e' ?% ]4 ~% e5 N$ ?$condition['_logic'] = "AND";% e6 _/ L6 a, N1 ]3 ]" @
$map['_complex']=$where;, J# D3 I9 H+ i7 @
$map['level']='0';" v  L" T1 o9 W- D0 x& d8 V7 ^
$map['_logic']='OR';! K7 s( V- J; l+ F% |  f! c
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
9 g. N2 a$ C0 f( K! D
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 20:25 , Processed in 0.109901 second(s), 20 queries .

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