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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
b、表达式查询
* U+ k. {, x& P9 t表达式        含义! }* V& x. J% p0 }' q( u6 p
EQ        等于(=)/ B2 f1 J0 @, g" ^  {- Y+ g
NEQ        不等于(<>)
) D1 ^: e5 f. L  G2 D1 LGT        大于(>)& T1 F7 Z1 Y$ R( k1 p4 C& h0 L
EGT        大于等于(>=), H, |* T- P8 q
LT        小于(<). F/ F: e8 J; ]% F1 t. t6 I: t
ELT        小于等于(<=); M% M9 p5 d0 ?6 k: u7 t( z
LIKE        模糊查询
, R' C  S1 N  t+ O- D, F9 [[NOT] BETWEEN        (不在)区间查询- A7 x5 o: @+ {; T% }
[NOT] IN        (不在)IN 查询
) I& q8 M1 Y4 OEXP        表达式查询,支持SQL语法
! D! q' c$ [8 p: \# j# n  ?0 T
/ R% Y! c# I! s: c
# m( J. p/ e8 Y+ L5 r$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件9 ~5 j& N* \+ Q6 r
M("User")->where($where)->select();//查询status为0的记录5 {  {) |3 ]( x6 j5 ]+ X4 u: O

! c7 i" U3 D, [1 y3、where方法数组查询例子
9 Z* |1 g0 V$ `+ ^& H1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
' i9 h- o& ~& L) u  i+ s$ U$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件
# T( z- r7 J  a2 L1 dM("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
; Q: N; S0 E6 W  L* d" K
* b, b$ x- E  x  i: e" Q$ x2、数组查询使用OR查询?比如,查询status等于0或者1的记录。! @9 j  Y% w5 g5 E9 ?( ?. D
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件' @3 B! o5 d, ^% P9 z
M("User")->where($where)->select();//查询status等于0或者1的记录  S& q3 A" ?# P! g7 _* ?
7 w: {! v5 N  O' c9 p- J% ]6 t6 s
3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。8 {, k$ z' z. V7 r, m
$where['createdate'] = array('EGT',"2016-04-20");
' L; k* ?: U8 E# k" d. Q# ^$where['status'] = '1';
$ D! V2 g8 r$ g$condition['_logic'] = "AND";
# `4 S" F! F: F; k2 S9 D' G( g$map['_complex']=$where;2 s$ W8 l/ ~; m8 d$ b+ [
$map['level']='0';1 y' Q* G2 r% Z1 W; U# J: ^3 X8 C& g
$map['_logic']='OR';! r$ y  V) C. ?5 i, L* j
M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录6 e$ K6 U# c2 w# C9 A- \. z
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-23 02:02 , Processed in 0.101304 second(s), 20 queries .

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