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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询( C, y5 ?  ]5 e1 D% o+ `
表达式        含义
2 M, j! \: b7 u! A0 QEQ        等于(=)
" y+ Q) [) y. w% PNEQ        不等于(<>)1 a/ h+ w, n. j  `% z
GT        大于(>), C1 |: X7 h" F7 C/ u
EGT        大于等于(>=)% J9 ^! M1 l* s5 J* T: p% K/ d8 h
LT        小于(<)+ ]! A3 i" h% R# |  O7 U
ELT        小于等于(<=)
7 p& u' h; h4 H; U+ I; O  U$ J/ KLIKE        模糊查询$ `; ~7 n: Z0 v( \  ^1 w( `
[NOT] BETWEEN        (不在)区间查询6 ?) L4 k4 ^( \9 E6 R4 Y
[NOT] IN        (不在)IN 查询4 J2 ~6 p* Y1 v9 v4 l1 b
EXP        表达式查询,支持SQL语法4 h  Z) q* D. {
4 E; j& g. s1 d+ J$ \

! u, s  |, T# r3 a0 `" d& v$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件% z" q" |* U+ K/ t% ]  H
M("User")->where($where)->select();//查询status为0的记录
; u& G: h9 N# M: K( _
! K9 i2 _6 ?5 r3、where方法数组查询例子! D- G, u- I7 r% Z
1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
! m% z0 ?) H- j. d0 |$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件" I  l+ i6 \# v1 `% j
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录# I) ?  N- n2 T# T$ c. I* n

' q! c; V& `( H2、数组查询使用OR查询?比如,查询status等于0或者1的记录。- x; B0 Y5 w. e- T. G% s
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
! {. b9 c8 X( m) y1 z  K" j) T5 rM("User")->where($where)->select();//查询status等于0或者1的记录" B: b8 d) x+ n) E3 X+ P0 N

% z1 ^1 t. z7 f) f, c3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
0 B! D" q) G, P1 X, N0 I$ o2 R- \9 S$where['createdate'] = array('EGT',"2016-04-20");
' a: L) x- b7 F$ k6 {: w/ W$where['status'] = '1';
( W) h2 V" Z$ ^& }( g' S- e& L7 V& l2 C$condition['_logic'] = "AND";
5 y8 [3 T" L; ?( o  t4 e+ X, h; \$map['_complex']=$where;
; W, d7 l/ B( X7 m. [( |6 j, ^$map['level']='0';
% w4 X2 M2 ^) ]/ y# o- N, C, k$map['_logic']='OR';
* g, y  T5 S; [M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录5 c3 j6 Y# d0 A+ h% q, q4 d% ?
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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