管理员
   
论坛积分
分
威望 点
贡献值 个
金币 枚
|
b、表达式查询
/ m) h8 U, J& {/ ~7 r" K7 B8 B" e表达式 含义- \% E% Z1 ?' X$ i, \! l
EQ 等于(=)
8 q% G$ S( W X- G i) X6 pNEQ 不等于(<>)
" {3 d6 y# o4 e( [5 S2 s$ e+ lGT 大于(>)2 t, X, d& g( R8 Y
EGT 大于等于(>=)
% p: K$ K% }/ V% @& k% D% HLT 小于(<)
* |! q6 F0 ~& z/ ~. _ELT 小于等于(<=)0 n# c; B" x5 Q$ d. y
LIKE 模糊查询
: f4 ?4 k1 Q. X' D; V3 b[NOT] BETWEEN (不在)区间查询
& C7 `, h* } s: i% N4 P- V* P[NOT] IN (不在)IN 查询
+ ~( y2 k' F) h6 e+ O0 [EXP 表达式查询,支持SQL语法
, B6 C% t/ g: Z3 j' H( q6 Q6 i
) z) v+ s" C5 O0 r- a. ^; l
9 O: u' E3 |9 r& b: w# c' F$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件" Z% t/ r4 e. g, w: c; _4 W
M("User")->where($where)->select();//查询status为0的记录
& ~ t) a* \" C, {9 K! g% r9 c% s/ I6 R3 D6 g- T0 a, Q6 F
3、where方法数组查询例子
% @3 p, F3 o5 N) f, d1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
( I' \. h2 k- {6 _$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件: b ^& u+ n: u O; R
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录, }' K% S# S n. a$ L
1 K0 K6 ~5 ]4 X7 D( }& z2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
. m+ e6 _/ r8 y' Z' p( F$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
0 M! e: X* X2 N" s. f, eM("User")->where($where)->select();//查询status等于0或者1的记录% i0 q, i }( l" o
9 Q& N& F% w h3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。2 `/ U) D. i9 w/ x4 }
$where['createdate'] = array('EGT',"2016-04-20");
! K, J) i& c# R; K- z% P$where['status'] = '1';
' X& U# d5 s# s7 {: [$condition['_logic'] = "AND";
, T- h5 {3 F7 Z7 C1 L' M$map['_complex']=$where;
, ^ J+ V. |- a: ]- q: P0 a$map['level']='0';
5 C( G6 w+ ~# y3 Y$map['_logic']='OR';
: k& h1 F) b- W. H/ n, SM("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
6 K# |" F& D* e$ |$ T |
|