今天来给你们讲下查询最经常使用但也是最复杂的where方法,where方法也属于模型类的连贯操做方法之一,主要用于查询和操做条件的设置。
where方法的用法是ThinkPHP查询语言的精髓,也是ThinkPHP ORM的重要组成部分和亮点所在,能够完成包括普通查询、表达式查询、快捷查询、区间查询、组合查询在内的查询操做。where方法的参数支持字符串和数组,虽然也可使用对象但并不建议。php
使用字符串条件直接查询和操做,例如:sql
$User = M("User"); // 实例化User对象thinkphp
$User->where('type=1 AND status=1')->select();数组
最后生成的SQL语句是安全
SELECT * FROM think_user WHERE type=1 AND status=1函数
若是使用3.1以上版本的话,使用字符串条件的时候,建议配合预处理机制,确保更加安全,例如:spa
$Model->where("id=%d and username='%s' and对象
xx='%f'",array($id,$username,$xx))->select();索引
或者使用:ip
$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方法支持快捷查询方式,能够进一步简化查询条件的写法,例如:
1、实现不一样字段相同的查询条件
$User = M("User"); // 实例化User对象
$map['name|title'] = 'thinkphp';
// 把查询条件传入查询方法
$User->where($map)->select();
查询条件就变成 name= 'thinkphp' OR title = 'thinkphp'
2、实现不一样字段不一样的查询条件
$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),混合查询中的特殊查询每次查询只能定义一个,因为采用数组的索引方式,索引相同的特殊查询会被覆盖。
1、字符串模式查询(采用_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 )
2、请求字符串查询方式
请求字符串查询是一种相似于URL传参的方式,能够支持简单的条件相等判断。
$map['id'] = array('gt','100');
$map['_query'] = 'status=1&score=100&_logic=or';
获得的查询条件是:`id`>100 AND (`status` = '1' OR `score` = '100')
3、复合查询
复合查询至关于封装了一个新的查询条件,而后并入原来的查询条件之中,因此能够完成比较复杂的查询条件组装。
例如:
$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();
屡次的数组条件表达式会最终合并,但字符串条件则只支持一次。