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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
8 `9 _6 q/ i# h5 O& O: `7 \) w表达式        含义! K+ Z3 t2 f0 w' v+ K
EQ        等于(=)
8 Z% L! ^. _( A) M9 C+ `NEQ        不等于(<>)
& |0 V# k; ~( v+ P1 dGT        大于(>)
9 e+ R) k! Y5 z; p6 Q$ {EGT        大于等于(>=)& Z% k# T( c( B7 r2 }& S
LT        小于(<)3 @3 V: n( d  a
ELT        小于等于(<=)' A8 S  `0 H& w
LIKE        模糊查询
$ G: I/ L- T* d- q" {[NOT] BETWEEN        (不在)区间查询0 Q7 x$ `1 f' \! G
[NOT] IN        (不在)IN 查询
6 V' w, _: c. i9 JEXP        表达式查询,支持SQL语法. g( h# U/ K; m' J

( M) q; A, J* O6 T  \, |4 }9 l$ _% l
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
: d2 |4 d9 s/ tM("User")->where($where)->select();//查询status为0的记录$ i0 q" I1 x' I" E* Z
$ q- M& N( l5 j- H
3、where方法数组查询例子
  I5 P2 C3 S4 A: V# y/ P* j1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。0 M! b" |6 c0 @" n- ?* I4 S
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
+ z* Y7 q! f0 U9 b% G& |; T/ ~% k5 O$ GM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
8 A2 I! I" V+ |# Q, p; ]$ a) f0 s! B" }! G  Y
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
, {# P: Y( I& g/ `5 z6 E  N( e  p8 M$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
( ?: g8 P/ R7 g7 Z% T) qM("User")->where($where)->select();//查询status等于0或者1的记录% ?. r' d4 Y1 m6 {1 s8 z8 x

& H4 b3 ^/ f- S4 H3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。* C2 ?9 U; j3 I. ?
$where['createdate'] = array('EGT',"2016-04-20");
8 F5 K1 r( H5 n; @$where['status'] = '1';
4 t3 n7 Y" c. S$ A% n$condition['_logic'] = "AND";; M5 Y6 l) U9 M0 \. {
$map['_complex']=$where;
: k' U, I1 y( h+ [2 x$map['level']='0';' p: Q- o- Q) h9 ~$ u1 w7 F" V
$map['_logic']='OR';: a+ d  z4 T" O+ g+ u7 |( @
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录: ^, @+ ~9 z7 h( k+ A) L- d
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 11:39 , Processed in 0.050951 second(s), 22 queries .

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