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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
' E' k3 f0 v$ x1 h; l2 h表达式        含义) F9 J& S) S  j& f1 I
EQ        等于(=)- @; D9 y9 g2 t2 T# v" S8 j5 s8 o; |: Q
NEQ        不等于(<>)0 ^: r- A7 @: M* a: `9 a7 G
GT        大于(>)
7 Q% f! J+ _  |% y# ^! PEGT        大于等于(>=), _4 g, Y; c  j* p" o6 s, I+ @
LT        小于(<)# ^5 h2 R1 D5 w
ELT        小于等于(<=)$ F% i4 T  s( I
LIKE        模糊查询
3 M6 |; w4 h1 O5 ^[NOT] BETWEEN        (不在)区间查询
! @7 r: m: L% z( U! m) x& O* [# D[NOT] IN        (不在)IN 查询$ q! q4 r6 w1 V# V% T+ o/ ?' {
EXP        表达式查询,支持SQL语法
8 N5 X  S% C' J, P$ V* m! D
; `$ [3 ?( p, j5 f8 Y1 }! H
0 L7 Y$ {& P/ {$ c$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件, C' T4 G, f. b6 Y
M("User")->where($where)->select();//查询status为0的记录
: R2 ], S. I3 R7 X! {$ ?& n
* {" L0 s% }% p' h9 a, a% z3 K( D0 {3、where方法数组查询例子' L4 U" n" x1 R) s3 M6 X
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
! @7 S# `  y& O$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
4 s0 Z( @& o- w$ K7 uM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录! R0 z; D0 M/ h; Y7 q. A

4 U' e# Z" _1 q2、数组查询使用OR查询?比如,查询status等于0或者1的记录。5 n; s' z6 x9 r+ r
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件! F: I& W9 c5 b6 Z5 ^% q
M("User")->where($where)->select();//查询status等于0或者1的记录! j- T0 y1 _# l/ P: `1 Z0 d8 x. @: N
9 K: y% _: W8 t: J
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
' P5 r& i9 n8 T' E3 r/ R$where['createdate'] = array('EGT',"2016-04-20");3 q% R4 N8 @6 S, N- Q/ U) _
$where['status'] = '1';- E9 {6 D6 `! ^
$condition['_logic'] = "AND";$ @/ H7 Z$ v& y4 T5 T4 Z
$map['_complex']=$where;
1 Q0 C0 H7 e* K5 k- B$map['level']='0';, P3 O% S3 @  _+ W9 F* E% S
$map['_logic']='OR';+ z, w( z* l" |3 o2 O4 V
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录" l' I+ [- D( T( W
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 21:26 , Processed in 0.099094 second(s), 19 queries .

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