1、字符串模式查询(_string)查询多个“与”条件中嵌套“与”条件
数组条件可以和字符串条件(采用_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、请求字符串查询方式(_query)查询“与”条件中嵌套“或”条件
请求字符串查询是一种类似于URL传参的方式,可以支持简单的条件相等判断。
$map['id'] = array('gt','100');$map['_query'] = 'status=1&score=100&_logic=or';
结果为:`id`>100 AND (`status` = '1' OR `score` = '100')
3、查询“或”条件(_logic)
$where['name'] = array('like', '%thinkphp%');$where['title'] = array('like','%thinkphp%');$where['_logic'] = 'or';结果为:( name like '%thinkphp%') OR ( title like '%thinkphp%')
4、复合查询(_complex)复合查询相当于封装了一个新的查询条件,然后并入原来的查询条件之中,所以可以完成比较复杂的查询条件组装。 例如:查询"与"条件和"或"条件相结合
$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%' ) )
ThinkPHP Where 条件中使用表达式---$map
Where 条件表达式格式为:
$map['字段名'] = array('表达式', '操作条件');ThinkPHP运算符 与 SQL运算符 对照表 TP运算符SQL运算符例子实际查询条件eq=$map['id'] = array('eq',100);等效于:$map['id'] = 100;neq!=$map['id'] = array('neq',100);id != 100gt>$map['id'] = array('gt',100);id > 100egt>=$map['id'] = array('egt',100);id >= 100lt<$map['id'] = array('lt',100);id < 100elt<=$map['id'] = array('elt',100);id <= 100likelike$map<'username'> = array('like','Admin%');username like 'Admin%'betweenbetween and$map['id'] = array('between','1,8');id BETWEEN 1 AND 8not betweennot between and$map['id'] = array('not between','1,8');id NOT BETWEEN 1 AND 8inin$map['id'] = array('in','1,5,8');id in(1,5,8)not innot in$map['id'] = array('not in','1,5,8');id not in(1,5,8)and(默认)and$map['id'] = array(array('gt',1),array('lt',10));(id > 1) AND (id < 10)oror$map['id'] = array(array('gt',3),array('lt',10), 'or');(id > 3) OR (id < 10)xor(异或)xor两个输入中只有一个是true时,结果为true,否则为false,例子略。1 xor 1 = 0exp综合表达式$map['id'] = array('exp','in(1,3,8)');$map['id'] = array('in','1,3,8');