thinkphp中查询,where条件集合写法

xiaoxiao2021-02-28  46

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');

转载请注明原文地址: https://www.6miu.com/read-2613771.html

最新回复(0)