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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
* F* i. ?2 |; i+ b7 `表达式        含义
: h2 Q& j6 Y. @3 K7 E( MEQ        等于(=)3 `# [( T" j6 K$ x( a* f
NEQ        不等于(<>)% ?9 w% F1 u7 |9 n3 f
GT        大于(>)
; E' H. M  g1 x0 A( g, i1 ]# lEGT        大于等于(>=)
' I' h* E, ~5 F! Q5 z3 NLT        小于(<)& S, w- i5 l6 L$ q
ELT        小于等于(<=)
; k) S- a& r) i5 Q/ N! d+ [4 v2 ELIKE        模糊查询& N* [" N1 G" _& @" o# y
[NOT] BETWEEN        (不在)区间查询8 Z8 t" M( F9 W0 ^4 ~
[NOT] IN        (不在)IN 查询# a) }! a+ W5 G" H4 W% ~' l0 n8 F/ L; Q
EXP        表达式查询,支持SQL语法8 y( C  K* s% ?/ O2 G' e5 R

1 S! B' U2 g" ]- V9 Q) D% ?3 |9 o
% }/ \" ~2 G& W8 R- Q) \5 A+ A$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件0 g" R7 m0 G: r4 x
M("User")->where($where)->select();//查询status为0的记录9 E; U) D/ O5 h$ X2 ]
: e! t- g) z+ k
3、where方法数组查询例子# J" I  z. G1 x% L6 x) {, y
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
; D( G$ G. z& G1 z( m% y; D' ]$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件; I( ~  r% t! r  m' W
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录( V7 g. _" y! J% p$ ], h7 s

' ]+ r. \+ w4 F7 ]" [: Z2、数组查询使用OR查询?比如,查询status等于0或者1的记录。* U' b3 c- C5 t% F, X' k! a7 {
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件+ w0 j5 L: H% ?% `4 J! J  |
M("User")->where($where)->select();//查询status等于0或者1的记录
) C# l; ^1 Y, i0 e; [5 t
0 k: H# s0 w4 S3 x7 G% a) p5 Z3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。) g0 L% j  K3 `! g& B; {. X" `/ C
$where['createdate'] = array('EGT',"2016-04-20");9 l4 h6 L# k3 H; V
$where['status'] = '1';
" q* r! C: O5 A' [8 R& N1 j% \$condition['_logic'] = "AND";
3 p0 d, |' j1 h  S4 m% I# t$map['_complex']=$where;
% r0 {3 b' d' j  o/ w& o0 X$map['level']='0';
; b3 t! h  p9 F1 q$map['_logic']='OR';8 ?; a# N% K- g
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录+ |- v+ q( j' Q( l& d' V1 }
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-5-20 08:16 , Processed in 0.122488 second(s), 19 queries .

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