PHP3.2.3 where or,ThinkPHP3.2.3框架下where的組合查詢and、or方法

在項目開發中,查詢數據時經常用到where條件查詢來過濾數據;

有時就需要一個input輸入框判斷多個字段查詢,這時候我們就需要使用組合查詢方法來實現;

說明:組合查詢的主體還是采用數組方式查詢,只是加入了一些特殊的查詢支持,包括字符串模式查詢(_string)、復合查詢(_complex)、請求字符串查詢(_query),混合查詢中的特殊查詢每次查詢只能定義一個,由於采用數組的索引方式,索引相同的特殊查詢會被覆蓋。

具體實現方法如下:

字符串模式查詢

數組條件可以和字符串條件(采用_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 )

請求字符串查詢方式

請求字符串查詢是一種類似於URL傳參的方式,可以支持簡單的條件相等判斷。

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值