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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
0 |7 X9 l* H; A# ?( D2 L' V  b* J表达式        含义
2 z. O6 K! s5 h4 t# L& bEQ        等于(=)
0 u7 z% [$ v1 O: ZNEQ        不等于(<>)
" Y! j% V6 W7 q6 VGT        大于(>)3 }% P2 x+ s- }4 \0 W
EGT        大于等于(>=)
. e" t8 Z  n- K- s. xLT        小于(<)
  Q# X- H+ o$ wELT        小于等于(<=)3 \& G* o* j7 B6 v& r! H
LIKE        模糊查询& J7 |3 l! d: U
[NOT] BETWEEN        (不在)区间查询+ U; x' E1 G! X0 @4 ^' I& U
[NOT] IN        (不在)IN 查询  l+ b% H- K! B! u" h5 w
EXP        表达式查询,支持SQL语法
6 \/ b6 q. I0 ~2 K  T0 B; Q) h
1 X3 H6 A, {, W& F1 O
' N0 D6 Q* Z" j6 t) o; c2 \- g; B$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
& a' K  J- D: d# w/ LM("User")->where($where)->select();//查询status为0的记录
( O4 C) `" q# g  K2 _1 N4 b8 y& B
3、where方法数组查询例子
8 y/ d. \  @. ^4 Z3 ~1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。6 {' m7 R: P: m3 ^8 |4 c, J
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件/ V) P  t0 _& M; F9 P
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
1 e+ m  G/ S0 |: @4 A- H8 w+ t' [( ~! y0 K* Y( w8 t1 x& Q
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
# S% y' D. S* A7 L) g$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
. i# a9 u1 y+ [* I" h' a5 qM("User")->where($where)->select();//查询status等于0或者1的记录
! g) c( T) B' A5 n- i. ^7 ^1 _
" d- E# W6 ~3 c( I( R3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
2 j3 |; d% x  I& y- x2 `$where['createdate'] = array('EGT',"2016-04-20");
/ k" W  l- \& s$where['status'] = '1';& `% a- h8 P% ?6 Y: a' t! ^
$condition['_logic'] = "AND";
  }8 K7 X% C3 Q4 m# e$map['_complex']=$where;' x0 }6 ~5 d+ t* |3 {5 W, h
$map['level']='0';
6 R! p9 w8 I1 p8 h7 _% U' S5 b$map['_logic']='OR';
/ B; u5 g0 g7 V+ R0 uM("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
: z6 N+ f- X6 C+ U6 T  R, T2 p1 s# ^
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-4-30 23:03 , Processed in 0.066510 second(s), 19 queries .

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