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

相關文章
相關標籤/搜索