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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
b、表达式查询
+ J2 y+ U7 C. Y% A) p3 [表达式        含义: e# \* z  B7 N: X$ c
EQ        等于(=)- H1 I4 s8 V  A9 K
NEQ        不等于(<>)
6 n% y; ~3 M, S/ w% i5 i  d6 x( jGT        大于(>)+ h; v1 M9 A0 d% E
EGT        大于等于(>=)4 B9 ]2 {" S* Y$ |- B/ y6 e% K
LT        小于(<)0 \, n( M7 P6 f7 M2 [( E! I
ELT        小于等于(<=)+ H- ~+ Z$ b- B0 N( U" \
LIKE        模糊查询
6 P8 @; X. i* t. L) ][NOT] BETWEEN        (不在)区间查询3 J: \- @# c/ ]/ ?- _9 i2 o
[NOT] IN        (不在)IN 查询+ W/ o* L5 c" A& f3 e, T. b7 w# z" u
EXP        表达式查询,支持SQL语法; a' A: N) s" S: G

7 y: E2 \* d, |1 [4 h
/ d( Z0 W- d* L' I7 I$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
  V& @& W& J9 n6 c, mM("User")->where($where)->select();//查询status为0的记录
0 ~: I: w0 D: V
1 J6 K+ ?: }* ^/ \# H3、where方法数组查询例子2 w9 v! x0 O+ h* x3 f
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
/ M" ]. R3 j' b# P# Z6 v2 j/ f$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件  i7 C9 M! ?7 d) X# L
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
3 Z9 m# u2 c& _7 W5 W  M1 q, E
5 y9 r7 O/ L6 V  y7 A2 U" G: L2、数组查询使用OR查询?比如,查询status等于0或者1的记录。$ k3 x# B( E$ c) i4 s1 L# L
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
* e! n" ^# n2 [7 J' ?& H8 `M("User")->where($where)->select();//查询status等于0或者1的记录
5 j5 U) b% l/ B- B) K# m* m( o2 I. g' Q! v2 Z
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
6 k, r* Z3 R. h4 W# u5 f; X9 L, G$where['createdate'] = array('EGT',"2016-04-20");
) V  Z. p- N) T$where['status'] = '1';2 d/ c9 y3 _/ J- Y; t
$condition['_logic'] = "AND";
! I' I, V4 l/ g$map['_complex']=$where;
$ K( R& {  S7 w  N3 W! j$map['level']='0';
; v7 s( N; B1 O) G7 Z/ l: J; w$map['_logic']='OR';! N. g+ X. t, P8 @0 h9 u. Q) n
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录( D5 Y6 R8 w7 L' U+ T; p8 m8 ?4 X
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 15:02 , Processed in 0.053042 second(s), 20 queries .

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