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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询# g. c! K, W4 |  K) x9 D
表达式        含义8 C: v6 C7 Y; m; H+ L
EQ        等于(=); M7 |( f) i- a- \" i$ X
NEQ        不等于(<>)
" X3 ~( |- B( U9 I+ O5 e* _GT        大于(>)
) l& R7 P+ l9 U8 j1 v: L" f* XEGT        大于等于(>=)8 U/ E! O, F, t' t0 Q
LT        小于(<)
0 y0 A8 }7 L  Z* d+ VELT        小于等于(<=)" h# o1 Y7 k( P3 o2 a+ e5 w+ _: M( C
LIKE        模糊查询* S& o; \6 y- }0 U! w/ V* A
[NOT] BETWEEN        (不在)区间查询5 |4 J* F1 Z- P1 [) Z
[NOT] IN        (不在)IN 查询
$ A, ~( }7 v0 d& t# ~# `: A& NEXP        表达式查询,支持SQL语法# u) i( W; r+ ?; _

2 i% {( i. L" \6 c4 f, b5 S: Q, b5 r4 M
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件# g( _2 r6 Q# d+ v& M+ k
M("User")->where($where)->select();//查询status为0的记录* c; Q* I% W' {( c# \- L
$ ~, [: B  x8 ^
3、where方法数组查询例子
: l' q' E4 p; c5 R1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。- v3 r! h- i  g4 Y' t/ H# x
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件% E; s) M  _/ X
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
4 O, F/ x# \1 ]; H# w! s* N# J8 T% P! l, ^3 M) \/ K
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。( l0 }( _7 O/ R1 K( _$ ]/ @, G
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
0 G4 i- r" m. [) D/ W* L' rM("User")->where($where)->select();//查询status等于0或者1的记录) m8 W) a' _% ^6 n& Y$ {

% ]9 i/ s' J( i5 _) b' i3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
8 o) \' X/ B7 X2 }/ P% o# V9 a$where['createdate'] = array('EGT',"2016-04-20");3 ^- T) B) h& s6 z2 i
$where['status'] = '1';
# N0 H, C6 d$ @, Z$ M) `& b$ w$condition['_logic'] = "AND";, ]' r$ [0 X) i  |6 C2 d5 n
$map['_complex']=$where;. O& a3 a0 R$ O# u
$map['level']='0';
2 w; l' a8 F8 e$map['_logic']='OR';/ j1 A" r/ V( K
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
+ ?* r: q( `* _3 H2 Z
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-5-1 00:46 , Processed in 0.047608 second(s), 20 queries .

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