管理员
论坛积分
分
威望 点
贡献值 个
金币 枚
|
b、表达式查询7 N" o/ N( [( i+ N
表达式 含义
5 K8 r0 B% P! h* oEQ 等于(=)
1 ?) A2 }: p0 R# ] _7 }; QNEQ 不等于(<>)
; L' ^0 J! V( `) S# nGT 大于(>)3 f( A1 q$ m7 |( a$ g/ f* s0 T
EGT 大于等于(>=)
$ j" V$ F5 Z* ^% uLT 小于(<)
& n1 v. q3 a" \7 o0 x9 p4 VELT 小于等于(<=)
- V2 R6 W. u$ f8 u1 B. E+ JLIKE 模糊查询! c! t& l5 l- [; C3 F7 z# ?/ a4 v
[NOT] BETWEEN (不在)区间查询, s; G) f5 P. D2 n7 _6 P8 b: a3 D
[NOT] IN (不在)IN 查询
$ Q9 U" Y; C# R# o! p9 T! T4 YEXP 表达式查询,支持SQL语法$ r5 l" \: n S, f( w1 t7 f
5 q2 z8 m8 F1 L" R1 J& M
5 K; c; u, p! Y: i/ | c. y$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
9 }& x% Q/ J* ^0 F- X! { g/ |M("User")->where($where)->select();//查询status为0的记录
8 E% M# F, J% h+ \) s9 w* K6 J0 P2 A* K& Q$ ~6 g% H2 J
3、where方法数组查询例子
$ O" o! h* }+ w3 T4 O1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
# ~# O- M, h6 e$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
+ [1 O6 x) `. e) a) h. LM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
% y( J* Z- d6 e1 U) n$ k% h4 w0 ?, m2 C1 z* e/ L' x
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
9 J1 h- q8 Z& D! P4 x8 S$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件2 w# y B$ c' x. O9 y$ ^8 E) `& S
M("User")->where($where)->select();//查询status等于0或者1的记录* N6 N! f( [8 L% u
5 e) N) K, ~! U5 Y2 o
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。6 h2 D; z7 c% U% ^2 S
$where['createdate'] = array('EGT',"2016-04-20");
* P* Q) `) ^6 Q" |3 Y& O7 W" }$where['status'] = '1';
; U! | Y; {1 P6 E$condition['_logic'] = "AND";) _9 ]6 N) l( t( X! \! `
$map['_complex']=$where;
/ d$ B* K+ B P9 z$map['level']='0';" s: N T! |2 X% h1 ~8 I2 G$ j
$map['_logic']='OR';
* R7 v( A5 t+ N6 JM("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录0 K( Y- T; _! ]4 i* z
|
|