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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
b、表达式查询# c0 r0 K, w: f+ [
表达式        含义0 _8 k# J- t6 Z' E) F
EQ        等于(=)3 R; z1 L- \' N1 M" X- h* t5 Y
NEQ        不等于(<>)& [: q( T7 Y! B$ w% c" @( _6 u
GT        大于(>)$ d: L8 |% q2 R4 M3 [* I2 f) d
EGT        大于等于(>=)* D; v6 g" j( }" o
LT        小于(<)
. u' D/ r1 S. W8 ^7 d! ZELT        小于等于(<=)
( w% X+ c2 l8 S, [& BLIKE        模糊查询
3 w8 r( q- U* K: t6 u( U. @! r[NOT] BETWEEN        (不在)区间查询0 k; b8 ~8 u9 `3 x
[NOT] IN        (不在)IN 查询
  ~. _  p/ S! @1 H- y3 w8 sEXP        表达式查询,支持SQL语法& H+ a8 ]6 m4 D: h  I  r# d
! i( ]: D7 M3 e3 T6 L) H& Y
$ V! S) k; R5 W1 _
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件1 c' K: b5 h9 Y5 i& q" ?- v* D
M("User")->where($where)->select();//查询status为0的记录
* u! K- p3 j' g  m+ l! v" @
3 h. w* c$ _9 @5 E8 k6 w& [0 _, \3、where方法数组查询例子( Q/ Y) R- O7 A- S
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。* P: G  F* c, x( l  B" \. ]  F
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
: y. E+ S3 V6 H) @& FM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
$ Q4 C8 v0 i! j( w# K! `# {0 \$ j1 i5 V4 s
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
" n. @- Q) \4 }9 p$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
7 [+ T( r3 H4 Y/ ~+ M, x: ]7 EM("User")->where($where)->select();//查询status等于0或者1的记录
! z9 C% Z8 J( r- \6 z
8 a5 Z& M: B& [; m3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
! k* _, d# s! @! Y' o. l0 O/ [$where['createdate'] = array('EGT',"2016-04-20");
( A5 e- i- B9 j! W4 c9 I9 h3 @$where['status'] = '1';' P: b0 F' \! j5 R+ g/ A- }
$condition['_logic'] = "AND";
# ~0 s$ F0 B: [% a, T4 A$map['_complex']=$where;
; _: |0 @! c; e- c( [1 V) [# L$map['level']='0';
4 a& R7 ]& Y+ E. G/ v6 a0 P% l$map['_logic']='OR';
* x3 N+ j- m/ X) A: tM("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
# y: X/ r- R( g
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-5-20 16:45 , Processed in 0.114657 second(s), 20 queries .

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