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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
; Q8 e' K# r$ G2 Z3 |表达式        含义
! n" y" g0 v% f9 m4 w8 ^/ Z, @EQ        等于(=)) p; e# q& B5 X$ P' s/ g7 U
NEQ        不等于(<>)8 z6 I  @- ^2 ?* ]
GT        大于(>)" l) \. A6 F; K1 m
EGT        大于等于(>=)' L. W- T6 [9 ^  n* j: R/ h9 x9 L
LT        小于(<)9 P9 `8 P- k7 T" }
ELT        小于等于(<=)
( r  E8 E+ ^5 H! b* HLIKE        模糊查询
9 f  j# }* z" C' Y3 V0 ]5 p/ u& [[NOT] BETWEEN        (不在)区间查询5 d, V3 K0 P) I% p
[NOT] IN        (不在)IN 查询3 t5 q$ i6 I% r- ~8 M
EXP        表达式查询,支持SQL语法- W2 I; u; `* [$ e9 _5 M
& m  z& x9 G2 |5 ^( q
1 q; A4 I" k& E; q( j& j" Y
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件+ u* p5 {$ y+ I/ ?7 h- ]) r
M("User")->where($where)->select();//查询status为0的记录
! R  S* a, z( G% V$ P  C* B
+ R( {/ |7 g, E# c# p8 o2 \! e3、where方法数组查询例子
" T& U  S( b& l( Z, T0 T9 g* g1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。& O& e5 N* S* ^) m
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件: R- ?& V" K! E" g
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录/ M, W* W9 `+ C. Z  t

+ G9 [2 p8 H& ]& t+ V  r2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
, y) j$ ?6 P, u- Y: i$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
* i: \' a& C! i4 qM("User")->where($where)->select();//查询status等于0或者1的记录5 b4 F( \1 H; I% [$ k% m9 P, U# r

' U9 `$ x! l" A/ O; b0 ~/ j! ~! e. i3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
9 a6 n+ b5 \2 i7 S$ [$where['createdate'] = array('EGT',"2016-04-20");
! k# W# ~! o) y# _- i2 d$where['status'] = '1';4 ?" U1 b" s) j1 [
$condition['_logic'] = "AND";
0 w7 Z& y5 i3 u& O% ~$map['_complex']=$where;8 w! _3 A& ]" x* [% g
$map['level']='0';6 O; `* R* {7 T& y# v! g
$map['_logic']='OR';0 I4 n+ p2 S" g* X1 ^9 u
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
+ i! ?6 T% H5 O) A) ?/ Q9 G1 ~
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-3-17 18:24 , Processed in 0.053736 second(s), 21 queries .

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