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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
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
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-3-16 19:03 , Processed in 0.048833 second(s), 19 queries .

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