ThinkPHP3.2.3框架下where的组合查询and、or方法

在项目开发中,查询数据时常常用到where条件查询来过滤数据;php

有时就须要一个input输入框判断多个字段查询,这时候咱们就须要使用组合查询方法来实现;thinkphp

说明:组合查询的主体仍是采用数组方式查询,只是加入了一些特殊的查询支持,包括字符串模式查询(_string)、复合查询(_complex)、请求字符串查询(_query),混合查询中的特殊查询每次查询只能定义一个,因为采用数组的索引方式,索引相同的特殊查询会被覆盖。数组

具体实现方法以下:spa

字符串模式查询

 数组条件能够和字符串条件(采用_string 做为查询条件)混合使用,例如:code

$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传参的方式,能够支持简单的条件相等判断。blog

$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语句是一致的。

相关文章
相关标签/搜索