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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询/ X2 y1 P1 ?1 g, y: a
表达式        含义  d, S$ q6 ~3 u6 l4 y, \# Y
EQ        等于(=)0 m5 ^: b' {; E/ ?, @5 f0 [4 z6 }- E
NEQ        不等于(<>)/ k3 ]8 ]# c6 ~: C
GT        大于(>)
9 s1 ^% l+ f3 L- h3 CEGT        大于等于(>=)" N% r0 J8 B* i) x- e* n" G3 Z
LT        小于(<)3 C/ [& m$ [; N
ELT        小于等于(<=)5 _' l7 ?7 Z+ g7 r
LIKE        模糊查询
9 j, O6 N' o( p7 k% j- X1 a0 }% o[NOT] BETWEEN        (不在)区间查询0 Q; Q. ^7 Q, W2 B  s
[NOT] IN        (不在)IN 查询7 T. g. Y$ Z0 E! a! H
EXP        表达式查询,支持SQL语法
1 t# N2 e1 i4 g; O
, n, h2 C! i8 b
" {" X6 J4 B+ `+ p) e) D$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件9 z) ]' T. O- Q: X) D" b
M("User")->where($where)->select();//查询status为0的记录8 l+ ]" z$ \  p* Q1 U- J
9 @% J; I1 P3 J: }+ J0 I4 ]
3、where方法数组查询例子
& U4 C% \2 o6 }' I1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。; j1 H6 U9 g' T7 N- B; a5 l
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件8 y( V+ f& z) v& W- D; |! P- G
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
5 e" k/ C" Z6 J  n* x2 C6 t
0 J6 ]  K) T1 a9 z$ ^- e- a$ F5 E2、数组查询使用OR查询?比如,查询status等于0或者1的记录。! R5 f; }3 G( e7 P, w* P+ Y& F
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件- m- g3 S4 ?% e; B% I8 o
M("User")->where($where)->select();//查询status等于0或者1的记录( P7 J* v9 q6 T' U6 c
' v4 ^2 |5 h6 ^
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
( j2 p7 r) x  ^. W, J$where['createdate'] = array('EGT',"2016-04-20");. {5 p' l& e$ J+ c' z
$where['status'] = '1';  `! \" {, k0 k- \
$condition['_logic'] = "AND";
+ f+ d% }' a* I$map['_complex']=$where;4 l$ b( m; s' F8 M# h- Y. H
$map['level']='0';  A6 M9 L; W3 V' ~
$map['_logic']='OR';* ?. N# L6 {& F: u$ C! U
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录7 v6 t4 \+ R) r' n7 A2 f' u4 f
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-3-17 20:21 , Processed in 0.072809 second(s), 20 queries .

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