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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
/ V) i- D, P: O2 b/ ]9 x表达式        含义
+ O- C7 t( d; x' ]EQ        等于(=)
8 O1 L& ~7 y+ ^0 f3 J/ _NEQ        不等于(<>)
  p% K1 ]$ g% y4 {: u" mGT        大于(>)
9 `4 ?6 C: Q- eEGT        大于等于(>=)6 a+ g6 F! a, t( B2 R9 ]- l
LT        小于(<)
8 m0 e/ P3 c* J( L! N. sELT        小于等于(<=)* W: F% @' D. E& ?: t. v9 U
LIKE        模糊查询; ^, j/ W: m: M* i
[NOT] BETWEEN        (不在)区间查询6 ^- T9 k% c5 {# f
[NOT] IN        (不在)IN 查询
7 i2 B! _" w  o* qEXP        表达式查询,支持SQL语法
2 |5 G; A8 u" ^+ S
6 F; N# e" }$ q4 M
7 m# m1 p$ v% p$ h$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件& S% K' O& Y" E" S
M("User")->where($where)->select();//查询status为0的记录% A6 S9 }3 x3 y4 k, A7 v

% y% u' M# m4 O7 P6 _3、where方法数组查询例子$ _1 h1 Y: y1 ~9 v) g. P+ W' \6 B* y  Z
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
3 i$ g2 _6 g! o7 v- ?. g$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件3 c9 H! K6 Y* J. T
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录' V8 B/ ?. Y* ]* x4 m" N; T

( L6 f) C6 g" x6 K# W5 Z6 q2、数组查询使用OR查询?比如,查询status等于0或者1的记录。0 m8 X! r2 ]: U2 n1 S% u4 O
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
  n. _! m3 B4 q% \; y4 P. aM("User")->where($where)->select();//查询status等于0或者1的记录5 D) S( S6 K: j
# K- `8 H' ?( P) d! w, v  ~4 m
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。$ ~( h. J& z/ o* y/ l
$where['createdate'] = array('EGT',"2016-04-20");  R8 Z7 L: D8 B" Y3 J
$where['status'] = '1';
- X# N  I# {: A! Z+ J/ m5 l" n$condition['_logic'] = "AND";
4 r7 \$ Y) N9 r7 N0 Z) T, A$map['_complex']=$where;
- ~' D$ T2 O. W' t' n$map['level']='0';
+ T- w4 G; B5 P( z$map['_logic']='OR';+ J$ Y( e% g7 I8 Z1 y
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
  p, a! Q/ [7 Y; L, e
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-5-8 15:27 , Processed in 0.118608 second(s), 19 queries .

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