Thinkphp的查詢條件and 和or同時使用即復合查詢

2017-06-23 1367 2 編輯:深圳網站建設 來源:互聯網

thinkphp 3.2快捷查詢OR查詢&分割表示AND查詢講解

快捷查詢方式是一種多字段查詢的簡化寫法,可以進一步簡化查詢條件的寫法,在多個字段之間用|分割表示OR查詢,用&分割表示AND查詢,可以實現下面的查詢,例如:

一、不同字段相同的查詢條件

$User = M("User"); // 實例化User對象

$map['name|title'] = 'thinkphp';

// 把查詢條件傳入查詢方法

$User->where($map)->select(); 

上面的查詢其實可以等效于

$User = M("User"); // 實例化User對象

$map['name'] = 'thinkphp';

$map['title'] = 'thinkphp';

$map['_logic'] = 'OR';

// 把查詢條件傳入查詢方法

$User->where($map)->select(); 

查詢條件就變成 name= 'thinkphp' OR title = 'thinkphp'

二、不同字段不同的查詢條件

$User = M("User"); // 實例化User對象

$map['status&title'] =array('1','thinkphp','_multi'=>true);

// 把查詢條件傳入查詢方法

$User->where($map)->select(); 

上面的查詢等效于:

$User = M("User"); // 實例化User對象

$map['status'] = 1;

$map['title'] = 'thinkphp';

// 把查詢條件傳入查詢方法

$User->where($map)->select(); 

'_multi'=>true必須加在數組的最后,表示當前是多條件匹配,這樣查詢條件就變成 status= 1 AND title = 'thinkphp'

,查詢字段支持更多的,例如:

$map['status&score&title'] = 

array('1',array('gt','0'),

'thinkphp','_multi'=>true);

等效于:

$map['status'] = 1;

 $map['score'] = array('gt',0);

$map['title'] = 'thinkphp';

查詢條件就變成 status= 1 AND score >0 AND title = 'thinkphp'

本站文章均為深正網站建設摘自權威資料,書籍,或網絡原創文章,如有版權糾紛或者違規問題,請即刻聯系我們刪除,我們歡迎您分享,引用和轉載,但謝絕直接搬磚和抄襲!感謝...
關注深正互聯
七星彩头尾