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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询% q9 L% O5 {, D
表达式        含义/ O, ?: M/ J6 A9 P2 _: B
EQ        等于(=)5 S2 \/ s6 @: H' _, i
NEQ        不等于(<>)' F! J. K2 P, A, a
GT        大于(>)
- e0 |0 T) o) J7 y: F$ gEGT        大于等于(>=)' h# T8 m* y$ e& N$ \
LT        小于(<)
5 b, l" n/ ]! a& q! ]% }ELT        小于等于(<=)
) ]+ e: g+ V/ J& c0 o. BLIKE        模糊查询& p2 R( t% {) j: `& v% {* m
[NOT] BETWEEN        (不在)区间查询. o. z! [* o! @+ O( q+ f
[NOT] IN        (不在)IN 查询5 q+ X$ o9 c- D* s: q( }1 P
EXP        表达式查询,支持SQL语法
; @" A' c# _$ G/ \+ {4 N, t: t, a7 \/ F8 O7 f4 Y
- N& d% k- Z- ^4 W, V- M1 D/ ]
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
& y* Y# q! n5 V5 Z' iM("User")->where($where)->select();//查询status为0的记录
, h9 R. d$ N2 |, F0 c3 M- D: _. j" R- f. w* a
3、where方法数组查询例子
  l) F1 Z! N& S" v! J- @1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。. q, h+ N+ t, O
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件: x& E3 `+ x) G7 `& ~+ ^
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录4 a3 X! a( M7 W( O8 @9 q
& m+ v; R3 G9 |8 k2 a$ n9 p
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
* A' V5 n5 l# F, _3 B( s, l$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
" U' S# U8 H0 U+ K! SM("User")->where($where)->select();//查询status等于0或者1的记录5 ^' i6 b# p$ H

5 W  T& p5 D0 e0 L. l" M3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
& k* j  J1 ^. |$where['createdate'] = array('EGT',"2016-04-20");( O# E. a/ x! Y  Q
$where['status'] = '1';
6 ~; _4 Y8 Y2 T8 D# z4 v$condition['_logic'] = "AND";
. i# r' g4 r" j1 b5 e, q. t$map['_complex']=$where;/ M- t& k. C4 t- |' n
$map['level']='0';/ }& \0 h& L* m, o; l9 u
$map['_logic']='OR';7 }# n- Y; ^; E  _
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录0 C% P% L- q$ \0 {. B. j5 d
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-5-2 11:10 , Processed in 0.166874 second(s), 21 queries .

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