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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询+ T5 F7 H/ `/ B; ^9 i( n
表达式        含义: m1 w+ I4 P) z2 M
EQ        等于(=)+ E% o: o& X# m2 v
NEQ        不等于(<>)
, _( L0 D/ G' ^; q0 B+ [GT        大于(>)
1 P' W0 S0 G2 e" y# s, k; jEGT        大于等于(>=)2 m  g) [% t6 t+ `- _2 N1 V
LT        小于(<)
) @" I. O! A" c' H+ jELT        小于等于(<=)+ A& J3 Q# o! U2 A6 p: N( ^
LIKE        模糊查询7 V9 x9 S. M* x/ Q, h8 q
[NOT] BETWEEN        (不在)区间查询0 w6 e! b% o) a/ c9 \
[NOT] IN        (不在)IN 查询
1 _/ U7 t8 e) T2 x9 b7 k6 S+ ]EXP        表达式查询,支持SQL语法9 u- a, Z2 [# p& `

* m7 J* a3 l4 ^' p8 [! M# j+ I5 K  W( B0 a; A% u5 |) E% w
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
7 q" h* G+ [" ]4 L8 KM("User")->where($where)->select();//查询status为0的记录
4 R& f+ a4 `! b  |! e' s
# m, G. c. i5 S3、where方法数组查询例子
: A" I! \3 Z* g6 G1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
  w( T9 z) n- J5 P  n( L, z4 \7 L$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件+ @" x3 \$ n6 Z. F
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录- W* p/ [. ?. `
& S  s9 L+ ]* t- T  t
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。
  _* u% u" K! z' w  c# X0 j$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
2 D% n$ Y! l# A" lM("User")->where($where)->select();//查询status等于0或者1的记录
$ [! v* H' O. Z3 G
# c4 e7 z2 M1 g# U5 G% x3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
# w" S+ Z! O& L& `) E$where['createdate'] = array('EGT',"2016-04-20");
+ e+ k3 |  f9 |$ ?+ c# Y3 V$where['status'] = '1';' b& U$ C& ?/ f0 D  ]
$condition['_logic'] = "AND";5 I* o1 l7 J) q
$map['_complex']=$where;
% |% U) A/ W7 ~6 T$map['level']='0';; h: x  N2 C7 F: c' n1 b; E# m
$map['_logic']='OR';8 }2 P8 j3 B, q- w9 U& A% |4 W5 }- p
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录
8 Y# z1 c( z" L+ \  y
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-3-17 21:49 , Processed in 0.053833 second(s), 20 queries .

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