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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
9 H6 n. p; ]/ W( ]1 ]& ]表达式        含义& ?5 V) L& ]$ ]" D# d" |
EQ        等于(=)
0 \( Q8 W; I4 y" w2 v: a7 \# YNEQ        不等于(<>)
$ x$ z0 f1 k& [GT        大于(>). A5 F% A6 C/ ~1 O4 a$ l) U
EGT        大于等于(>=)
) Z: x2 E, {3 \3 L/ S% |3 ILT        小于(<)8 d  F4 `* |9 N0 R
ELT        小于等于(<=), |* ^2 O) N9 G: \
LIKE        模糊查询- g8 k7 U3 n( W, Q. d& G
[NOT] BETWEEN        (不在)区间查询
* ]1 U: }  \: N( V. W6 C[NOT] IN        (不在)IN 查询& I( U7 N) e" N
EXP        表达式查询,支持SQL语法7 p2 ?/ f" q, |; B
( l! e, p! [1 n- B, q

2 p9 r  z  G) `" z, ]9 q6 \' L& Z$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
2 J  u+ l+ [" d, ^( C& }' mM("User")->where($where)->select();//查询status为0的记录% O7 A+ G% s6 }1 C' a/ p/ H  Y
4 q) A  P5 p0 F, \; t+ s
3、where方法数组查询例子/ ]" \% d7 r% ^/ w3 T! g
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
( g7 f/ r. l1 z: |& R1 H: _# V$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件* R) k6 `% |+ `" y
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
4 y+ |2 x4 }$ ^; L! [+ O# A; c7 a+ X$ G; Y- e$ E
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。, A6 k" h, `9 `  G9 M6 S- L# ^: [
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
  |: u- O& F: U1 @/ U/ i% ?" SM("User")->where($where)->select();//查询status等于0或者1的记录
' [! B4 i! t) J$ i  P( k6 x0 L/ x4 L  \
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。9 `0 g! z* O+ Y; o! g, l5 H
$where['createdate'] = array('EGT',"2016-04-20");* L/ b* M' ~* A2 T! G+ B
$where['status'] = '1';" I1 h/ M0 ~  _4 r4 S, y% X
$condition['_logic'] = "AND";, ]6 ?- c6 a2 D- D
$map['_complex']=$where;
& Y0 Q( ]/ ]; m$map['level']='0';
6 e$ ~9 i! P6 E- ?/ `5 w3 G, z$map['_logic']='OR';& V9 s, D1 m. P. x4 S
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
+ b: Q3 k! B$ O
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-6-4 12:59 , Processed in 0.065913 second(s), 19 queries .

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