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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询# p2 R1 n, |0 I. i/ {4 r8 G1 U
表达式        含义
! q: Z; _: |- V7 m; FEQ        等于(=)
- e: K2 ?0 _' t* U$ GNEQ        不等于(<>)
) d7 o+ Q3 T  Y, W# NGT        大于(>)
) b. I) Y& P+ E: ^+ nEGT        大于等于(>=)
9 Y5 b  J' ~& @/ |* HLT        小于(<)! ~* Y# C$ @- N6 b
ELT        小于等于(<=)
4 g0 J0 m5 S( {4 J* J; uLIKE        模糊查询
' r: ~: U) N/ i- ]5 l, Q[NOT] BETWEEN        (不在)区间查询
9 y, W! R. t) w  ]/ f/ Y( }1 r[NOT] IN        (不在)IN 查询# ~- T3 _7 t4 y# z: H) D  M7 o
EXP        表达式查询,支持SQL语法
( |. B9 m5 ^4 w% k+ O2 a0 J% J. t& R3 C) ~6 Y- i  q/ c
: Y" A4 ^% C) k9 M3 a9 E9 O
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件! l, B. ]1 ~- f! \) k; G- Z
M("User")->where($where)->select();//查询status为0的记录
! m; u8 u% _' w
! u/ h1 V4 e! Q9 k$ r3、where方法数组查询例子
* h% s, O& ~% J" A0 Y9 N' B8 |1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。0 w6 I8 a- l6 c% ^; l
$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件! S9 q8 _: R. B0 Y+ V. x, N- T, H
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
2 {1 R* @& ^1 m" N: G$ E, f6 h$ e+ \: U* e& ]& f+ Z$ F
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。# o2 Y- Q, c* s
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
: _( ~9 K1 W$ ~" ~. sM("User")->where($where)->select();//查询status等于0或者1的记录# u! t' B4 T% Z% b3 L$ g% N7 b- y
# |' D% u5 J  y/ }2 a
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
8 E/ I1 G. S. C/ _- f$where['createdate'] = array('EGT',"2016-04-20");! w% C3 Y0 O3 h) c: n' x6 g: L
$where['status'] = '1';1 o' p8 u8 z" E& O
$condition['_logic'] = "AND";. N$ T8 P# s4 D. Z- q) i% ]1 K1 {, `, k
$map['_complex']=$where;3 c. b( y3 Z' B* |9 P" j
$map['level']='0';- n& a8 `8 S' v3 ]3 ]5 Z( }
$map['_logic']='OR';; L" {6 u0 l" }# I
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录9 P) T% G9 k$ G% T6 |
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-5-2 14:34 , Processed in 0.058616 second(s), 20 queries .

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