where方法的用法是ThinkPHP查询语言的精髓,也是ThinkPHP ORM的重要组成部分和亮点所在,可以完成包括普通查询、表达式查询、快捷查询、区间查询、组合查询在内的查询操作。where方法的参数支持字符串和数组,虽然也可以使用对象但并不建议。
字符串条件
使用字符串条件直接查询和操作,例如:

$User = M("User"); // 实例化User对象
    $User->where('type=1 AND status=1')->select();

最后生成的SQL语句是

SELECT * FROM think_user WHERE type=1 AND status=1

如果使用3.1以上版本的话,使用字符串条件的时候,建议配合预处理机制,确保更加安全,例如:

$Model->where("id=%d and username='%s' and
    xx='%f'",array($id,$username,$xx))->select();

或者使用:

$Model->where("id=%d and username='%s' and xx='%f'",$id,$username,$xx)->select();

如果$id变量来自用户提交或者URL地址的话,如果传入的是非数字类型,则会强制格式化为数字格式后进行查询操作。
字符串预处理格式类型支持指定数字、字符串等,具体可以参考vsprintf方法的参数说明。
数组条件
数组条件的where用法是ThinkPHP推荐的用法。
普通查询
最简单的数组查询方式如下:

$User = M("User"); // 实例化User对象
    $map['name'] = 'thinkphp';
    $map['status'] = 1;
    // 把查询条件传入查询方法
    $User->where($map)->select();

最后生成的SQL语句是

SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1

表达式查询
上面的查询条件仅仅是一个简单的相等判断,可以使用查询表达式支持更多的SQL查询语法,查询表达式的使用格式:

$map['字段1']  = array('表达式','查询条件1');
    $map['字段2']  = array('表达式','查询条件2');
    $Model->where($map)->select(); // 也支持

表达式不分大小写,支持的查询表达式有下面几种,分别表示的含义是:
表达式     含义
EQ     等于(=)
NEQ     不等于(<>)
GT     大于(>)
EGT     大于等于(>=)
LT     小于(<)
ELT     小于等于(<=)
LIKE     模糊查询
[NOT] BETWEEN     (不在)区间查询
[NOT] IN     (不在)IN 查询
EXP     表达式查询,支持SQL语法
示例如下:
EQ :等于(=)
例如:

$map['id']  = array('eq',100);

和下面的查询等效

$map['id']  = 100;

表示的查询条件就是 id = 100

NEQ: 不等于(<>)
例如:

$map['id']  = array('neq',100);

表示的查询条件就是 id <> 100

GT:大于(>)
例如:

$map['id']  = array('gt',100);

表示的查询条件就是 id > 100

EGT:大于等于(>=)
例如:

$map['id']  = array('egt',100);

表示的查询条件就是 id >= 100

LT:小于(<)
例如:

$map['id']  = array('lt',100);

表示的查询条件就是 id < 100

ELT: 小于等于(<=)
例如:

$map['id']  = array('elt',100);

表示的查询条件就是 id <= 100

[NOT] LIKE: 同sql的LIKE
例如:

$map['name'] = array('like','thinkphp%');

查询条件就变成 name like 'thinkphp%'
如果配置了DB_LIKE_FIELDS参数的话,某些字段也会自动进行模糊查询。例如设置了:

'DB_LIKE_FIELDS'=>'title|content'

的话,使用

$map['title'] = 'thinkphp';

查询条件就会变成 name like '%thinkphp%'
支持数组方式,例如

$map['a'] =array('like',array('%thinkphp%','%tp'),'OR');
    $map['b'] =array('notlike',array('%thinkphp%','%tp'),'AND');

生成的查询条件就是:
(a like '%thinkphp%' OR a like '%tp') AND (b not like '%thinkphp%' AND b not like '%tp')

[NOT] BETWEEN :同sql的[not] between, 查询条件支持字符串或者数组,例如:

$map['id']  = array('between','1,8');

和下面的等效:

$map['id']  = array('between',array('1','8'));

查询条件就变成 id BETWEEN 1 AND 8

[NOT] IN: 同sql的[not] in ,查询条件支持字符串或者数组,例如:

$map['id']  = array('not in','1,5,8');

和下面的等效:

$map['id']  = array('not in',array('1','5','8'));

查询条件就变成 id NOT IN (1,5, 8)

EXP:表达式,支持更复杂的查询情况
例如:

$map['id']  = array('in','1,3,8');

可以改成:

$map['id']  = array('exp',' IN (1,3,8) ');

exp查询的条件不会被当成字符串,所以后面的查询条件可以使用任何SQL支持的语法,包括使用函数和字段名称。

查询表达式不仅可用于查询条件,也可以用于数据更新,例如:

$User = M("User"); // 实例化User对象
    // 要修改的数据对象属性赋值
    $data['name'] = 'ThinkPHP';
    $data['score'] = array('exp','score+1');// 用户的积分加1
    $User->where('id=5')->save($data); // 根据条件保存修改的数据

快捷查询
where方法支持快捷查询方式,可以进一步简化查询条件的写法,例如:
一、实现不同字段相同的查询条件

$User = M("User"); // 实例化User对象
    $map['name|title'] = 'thinkphp';
    // 把查询条件传入查询方法
    $User->where($map)->select();

查询条件就变成 name= 'thinkphp' OR title = 'thinkphp'

二、实现不同字段不同的查询条件

$User = M("User"); // 实例化User对象
    $map['status&title'] =array('1','thinkphp','_multi'=>true);
    // 把查询条件传入查询方法
    $User->where($map)->select();

'_multi'=>true必须加在数组的最后,表示当前是多条件匹配,这样查询条件就变成 status= 1 AND title = 'thinkphp' ,查询字段支持更多的,例如:
$map['status&score&title'] =array('1',array('gt','0'),'thinkphp','_multi'=>true);
查询条件就变成 status= 1 AND score >0 AND title = 'thinkphp'

注意:快捷查询方式中“|”和“&”不能同时使用。
区间查询
where方法支持对某个字段的区间查询,例如:

$map['id'] = array(array('gt',1),array('lt',10)) ;

得到的查询条件是: (`id` > 1) AND (`id` < 10)

$map['id'] = array(array('gt',3),array('lt',10), 'or') ;

得到的查询条件是: (`id` > 3) OR (`id` < 10)

$map['id']  = array(array('neq',6),array('gt',3),'and');

得到的查询条件是:(`id` != 6) AND (`id` > 3)
最后一个可以是AND、 OR或者 XOR运算符,如果不写,默认是AND运算。
区间查询的条件可以支持普通查询的所有表达式,也就是说类似LIKE、GT和EXP这样的表达式都可以支持。另外区间查询还可以支持更多的条件,只要是针对一个字段的条件都可以写到一起,例如:

$map['name']  = array(array('like','%a%'), array('like','%b%'), array('like','%c%'), 'ThinkPHP','or');

最后的查询条件是:

(`name` LIKE '%a%') OR (`name` LIKE '%b%') OR (`name` LIKE '%c%') OR (`name` = 'ThinkPHP')

组合查询
组合查询用于复杂的查询条件,如果你需要在查询的时候同时偶尔使用字符串却又不希望丢失数组方式的灵活的话,可以考虑使用组合查询。
组合查询的主体还是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string)、复合查询(_complex)、请求字符串查询(_query),混合查询中的特殊查询每次查询只能定义一个,由于采用数组的索引方式,索引相同的特殊查询会被覆盖。
一、字符串模式查询(采用_string 作为查询条件)
数组条件还可以和字符串条件混合使用,例如:

$User = M("User"); // 实例化User对象
    $map['id'] = array('neq',1);
    $map['name'] = 'ok';
    $map['_string'] = 'status=1 AND score>10';
    $User->where($map)->select();

最后得到的查询条件就成了:
( `id` != 1 ) AND ( `name` = 'ok' ) AND ( status=1 AND score>10 )

二、请求字符串查询方式
请求字符串查询是一种类似于URL传参的方式,可以支持简单的条件相等判断。

$map['id'] = array('gt','100');
    $map['_query'] = 'status=1&score=100&_logic=or';

得到的查询条件是:`id`>100 AND (`status` = '1' OR `score` = '100')

三、复合查询
复合查询相当于封装了一个新的查询条件,然后并入原来的查询条件之中,所以可以完成比较复杂的查询条件组装。
例如:

$where['name']  = array('like', '%thinkphp%');
    $where['title']  = array('like','%thinkphp%');
    $where['_logic'] = 'or';
    $map['_complex'] = $where;
    $map['id']  = array('gt',1);

查询条件是
( id > 1) AND ( ( name like '%thinkphp%') OR ( title like '%thinkphp%') )
复合查询使用了_complex作为子查询条件来定义,配合之前的查询方式,可以非常灵活的制定更加复杂的查询条件。
很多查询方式可以相互转换,例如上面的查询条件可以改成:

$where['id'] = array('gt',1);
    $where['_string'] = ' (name like "%thinkphp%")  OR ( title like "%thinkphp") ';

最后生成的SQL语句是一致的。
多次调用
3.1.3版本开始,where方法支持多次调用,但字符串条件只能出现一次,例如:

$map['a'] = array('gt',1);
    $where['b'] = 1;
    $Model->where($map)->where($where)->where('status=1')->select();

多次的数组条件表达式会最终合并,但字符串条件则只支持一次。

转自:http://www.splaybow.com/post/thinkphp-where-function.html

转载于:https://www.cnblogs.com/lvchenfeng/p/4917901.html

ThinkPHP中where()方法的使用相关推荐

  1. php调用另一个php文件里的变量的值,thinkphp中一个方法调用另一个步骤的变量

    thinkphp中一个方法调用另一个方法的变量 //实例化上传类 public function upload() { $upload = new Upload(); $upload->maxS ...

  2. php中sisson用法,thinkPHP中session()方法用法详解

    本文实例讲述了thinkPHP中session()方法用法.分享给大家供大家参考,具体如下: 系统提供了Session管理和操作的完善支持,全部操作可以通过一个内置的session函数完成. 用法 s ...

  3. php create()方法,ThinkPHP中create()方法自动验证实例

    ThinkPHP中create()方法自动验证实例2020-06-16 04:24:32 自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验 ...

  4. php大m大d,ThinkPHP中M方法与D方法区别

    [前言] ? ? ? 本文总结下ThinkPHP中M方法与D方法区别,以下均为个人见解.如有误解请指正 ? [主体] (一)个人见解: ? ? ? ?M()方法参数可选,有参数时表示实例化父类模型的同 ...

  5. ThinkPHP中vendor()方法导入第三方类库的用法!ThinkPHP 3.2 vendor()方法的深入研究!

    ThinkPHP vendor 方法导入第三方类库 第三方类库 第三方类库指除了 ThinkPHP 框架.应用项目类库之外的其他类库,一般由第三方系统或产品提供,如 Smarty.Zend 等系统的类 ...

  6. PHP的create方法,Thinkphp中Create方法深入探究

    由于工作原因在thinkPHP的create()方法上遇到了问题,所以跟踪了create(),从而进一步探究了create()方法. 原来create()方法原来有两个参数,本文就此作简要说明,需要的 ...

  7. thinkphp中data方法

    data方法也是模型类的连贯操作方法之一,用于设置当前要操作的数据对象的值,可能大家不太习惯用这个方法,今天来讲解下如何用好data方法. 用法 写操作 通常情况下我们都是通过create方法或者赋值 ...

  8. thinkphp中I方法

    概述 正如你所见到的一样,I方法是ThinkPHP众多单字母函数中的新成员,其命名来自于英文Input(输入),主要用于更加方便和安全的获取系统输入变量,可以用于任何地方,用法格式如下: I('变量类 ...

  9. php getfield,ThinkPHP中getField()方法的使用

    //**************************************************************************************** //  getFi ...

最新文章

  1. 2022-2028年中国氢化丁晴橡胶行业市场研究及前瞻分析报告
  2. 网络负载均衡相关技术-DNS
  3. CIO如何做到卓有成效?
  4. 交换机的VTP技术应用实训
  5. PHP获取IP的多种方式解析
  6. 织梦 mail.class.php,详解织梦模板DEDECMS核心类TypeLink.class.php功能分析
  7. CentOS 5 上安装git
  8. Linux内核驱动如何编写?我们先从字符驱动入门开始
  9. 深度好文!男性在青年时期应为自己做哪些投资?
  10. Android接收系统广播
  11. 《21天学通HTML+CSS+JavaScript Web开发(第7版)》——1.4 统一资源定位符
  12. Tomcat 下面使用软连接指向真实的上传文件夹
  13. 下面哪个对象能代表当前的HTML文件,GD:JAVA考试选择题
  14. comsol 超声声场模拟_Comsol Multiphysics 声场仿真模块整体介绍
  15. MicroSIP软电话安装配置说明
  16. 【65】如何通过sys文件系统remove和probe一个PCI设备
  17. Typora快捷键【官方文档】
  18. 深入学习ElasticSearch(四)——mapping的详细讲解
  19. crypto661-rabin(网鼎杯2022-未完成)
  20. adb设置代理与取消代理

热门文章

  1. accsess转成mysql语句_access数据库转mysql经验分享
  2. 198. 打家劫舍 golang 动态规划 数组越界
  3. Redis运维和开发学习笔记(2) redis持久化
  4. Linux_linux常用工具之make/makefile详解
  5. (C语言版)链表(二)——实现单向循环链表创建、插入、删除、释放内存等简单操作
  6. 107. 二叉树的层次遍历 II
  7. 从青铜到王者的路线,java不同系统间数据同步
  8. 丁香园 武汉 神童_杭州、武汉、成都哪个城市更适合程序员发展
  9. linux基础文件管理软硬链接
  10. J - Borg Maze