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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
2 p2 k  M; }/ {$ G! l6 B8 t表达式        含义
* u0 O9 H7 n* k9 }1 eEQ        等于(=)1 z% i* l& c8 G$ h8 v: V& o; A
NEQ        不等于(<>)
+ `" g1 b5 H) }$ @GT        大于(>)- [: v  W, @; I9 S9 ^
EGT        大于等于(>=)
# v9 T7 M4 k9 T, P" f! lLT        小于(<)
  ]" {& p6 N9 ]% z1 Y) `ELT        小于等于(<=)
8 t9 S' f* y  x; Z6 U; jLIKE        模糊查询" M6 ]* a  j$ R/ X) r5 @1 C. t
[NOT] BETWEEN        (不在)区间查询5 E5 X, ?/ Z5 g+ y7 l& C
[NOT] IN        (不在)IN 查询! w+ j6 C# w: {
EXP        表达式查询,支持SQL语法
; u' }$ Q- S6 \8 U( B& h8 v/ e
" t+ f8 b6 T) m5 H$ D' w
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件2 _* O" x; x$ m3 R
M("User")->where($where)->select();//查询status为0的记录' s- g' j1 N1 J3 [; E! f" P
1 }& \" b3 j- P/ m
3、where方法数组查询例子5 w" ?& Y, ]( r: [2 E% _3 |2 K6 Q
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
& ^: G$ Q, G* X2 R% [. p' o* c$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
5 U+ }9 J) D& w" xM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
2 P$ A$ O( N) \' \' s+ R
0 S2 u! N' l' ~- l. ]# k2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
: S0 D  c) l1 E. Y; [+ D6 {  t$ m$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
) t$ e: o% W, |2 D: GM("User")->where($where)->select();//查询status等于0或者1的记录' Y' p$ Z$ R- x: ^8 i' F$ w
2 Y# h) ~1 [( X* E
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。  ?9 s8 W  j0 b$ I0 k: l  \
$where['createdate'] = array('EGT',"2016-04-20");7 B1 j; ]( T: C
$where['status'] = '1';
0 @1 ~6 S2 k( K! W' t. k5 ?) U  M$condition['_logic'] = "AND";
. L1 y: [% N  F& ?0 T. a$map['_complex']=$where;4 X% {2 |9 q& `/ w  e
$map['level']='0';
) I  R6 u( d0 d( \# H$map['_logic']='OR';
" Q1 [7 ^7 p6 J0 Q, {9 d, ]3 SM("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
4 }/ j6 E( B  K% f3 G9 N
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 22:02 , Processed in 0.118047 second(s), 19 queries .

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