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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2018-9-14 13:13:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
b、表达式查询
6 ~) Y( O' c9 D0 v6 h5 D4 b+ o% t# |+ S表达式        含义
. P/ l3 g1 p9 P. B4 ^EQ        等于(=)
# O3 q) w& L& J9 n5 lNEQ        不等于(<>)
, T, L1 w% M/ Y( U( hGT        大于(>)
7 I: z/ y; k0 u% m4 VEGT        大于等于(>=): D' i8 [7 h8 e' l5 d" D8 z; y4 e
LT        小于(<)8 m) l- }/ R  z# c0 s! b
ELT        小于等于(<=)4 r7 r* T8 [4 ^  t! b, p$ M
LIKE        模糊查询
( R2 q% Q% }8 [. ?# [3 p$ W( u; W[NOT] BETWEEN        (不在)区间查询
* t4 K' c! W; I4 J[NOT] IN        (不在)IN 查询
7 ^$ F/ _% y; GEXP        表达式查询,支持SQL语法# M# a' x# m6 y. C* m. w

  L5 M7 m) F7 r5 A, _% t+ Y! N* z1 m: D% O& a
$where['status'] = array("eq",0);//字段就是数组的下标,值就是对应的条件
3 u+ S, `( S( D- @+ ~M("User")->where($where)->select();//查询status为0的记录
  M7 R- G, g3 f( i' }2 k9 P8 I! m5 l. Q/ N5 h: `
3、where方法数组查询例子
3 f# ]: X% j7 T9 U( V5 @1、如何使用数组实现同一字段多个条件?比如,查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录。
$ v- x  n, L: Q: y1 e. b3 t$where['createdate'] = array(array('EGT',"2016-04-20"),array('ELT',"2016-04-23"));//使用一个二维数组就可以解决同一字段多个条件9 t) }* b) @7 T
M("User")->where($where)->select();//查询createdate大于等于2016年4月20日并且小于等于2016年4月23日的记录
3 S  D/ ?3 V! f& z+ O7 o0 m1 H* A$ t/ M! C# k2 v8 d  J
2、数组查询使用OR查询?比如,查询status等于0或者1的记录。0 W* X* X/ \( M0 U- [
$where['status'] = array(array('EQ',"0"),array('EQ',"1"),"OR");//使用一个二维数组就可以解决同一字段多个条件
3 M/ t0 k8 G) O' f# y# K2 k3 {M("User")->where($where)->select();//查询status等于0或者1的记录! ]2 |; U' f3 ]( E1 f" b6 l( M$ Y

6 |& I( L6 D( V# P* p6 W/ \) d3、多个条件里既有AND又有OR的数组查询?比如,查询createdate小于等于2016年4月20日并且status为1或者level为0的记录。
- A4 b1 `/ a8 a$where['createdate'] = array('EGT',"2016-04-20");) I- I8 Z8 t. f  B2 L0 q2 ]
$where['status'] = '1';) F6 Z. q- E! i  r+ G' H
$condition['_logic'] = "AND";$ B( y$ O) Q& `/ e- n% b& R( w3 p
$map['_complex']=$where;' {6 R! e- N2 P; S. \, _% a
$map['level']='0';$ n, m& r$ @9 n% P  L. {1 y
$map['_logic']='OR';
8 p: I3 `7 O. v7 ^; z3 F- K" \M("User")->where($map)->select();//查询createdate小于等于2016年4月20日并且status为1或者level为0的记录* O4 i) O; ]* ?0 p# z4 K8 N
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-23 07:17 , Processed in 0.126005 second(s), 19 queries .

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