本文介紹ThinkPHP的where()方法的用法。where方法可以用于對(duì)數(shù)據(jù)庫(kù)操作的結(jié)果進(jìn)行篩選。即SQL查詢(xún)語(yǔ)句中的where子句。
今天來(lái)給大家講下查詢(xún)最常用但也是最復(fù)雜的where方法,where方法也屬于模型類(lèi)的連貫操作方法之一,主要用于查詢(xún)和操作條件的設(shè)置。
where方法的用法是ThinkPHP查詢(xún)語(yǔ)言的精髓,也是ThinkPHP ORM的重要組成部分和亮點(diǎn)所在,可以完成包括普通查詢(xún)、表達(dá)式查詢(xún)、快捷查詢(xún)、區(qū)間查詢(xún)、組合查詢(xún)?cè)趦?nèi)的查詢(xún)操作。where方法的參數(shù)支持字符串和數(shù)組,雖然也可以使用對(duì)象但并不建議。
字符串條件
使用字符串條件直接查詢(xún)和操作,例如:
$User = M("User"); // 實(shí)例化User對(duì)象
$User->where('type=1 AND status=1')->select();
最后生成的SQL語(yǔ)句是
SELECT * FROM think_user WHERE type=1 AND status=1
如果使用3.1以上版本的話,使用字符串條件的時(shí)候,建議配合預(yù)處理機(jī)制,確保更加安全,例如:
$Model->where("id=%d and username='%s' and
xx='%f'",array($id,$username,$xx))->select();
或者使用:
$Model->where("id=%d and username='%s' and xx='%f'",$id,$username,$xx)->select();
如果$id變量來(lái)自用戶(hù)提交或者URL地址的話,如果傳入的是非數(shù)字類(lèi)型,則會(huì)強(qiáng)制格式化為數(shù)字格式后進(jìn)行查詢(xún)操作。
字符串預(yù)處理格式類(lèi)型支持指定數(shù)字、字符串等,具體可以參考vsprintf方法的參數(shù)說(shuō)明。
數(shù)組條件
數(shù)組條件的where用法是ThinkPHP推薦的用法。
普通查詢(xún)
最簡(jiǎn)單的數(shù)組查詢(xún)方式如下:
$User = M("User"); // 實(shí)例化User對(duì)象
$map['name'] = 'thinkphp';
$map['status'] = 1;
// 把查詢(xún)條件傳入查詢(xún)方法
$User->where($map)->select();
最后生成的SQL語(yǔ)句是
SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1
表達(dá)式查詢(xún)
上面的查詢(xún)條件僅僅是一個(gè)簡(jiǎn)單的相等判斷,可以使用查詢(xún)表達(dá)式支持更多的SQL查詢(xún)語(yǔ)法,查詢(xún)表達(dá)式的使用格式:
$map['字段1'] = array('表達(dá)式','查詢(xún)條件1');
$map['字段2'] = array('表達(dá)式','查詢(xún)條件2');
$Model->where($map)->select(); // 也支持
表達(dá)式不分大小寫(xiě),支持的查詢(xún)表達(dá)式有下面幾種,分別表示的含義是:
表達(dá)式 含義
EQ 等于(=)
NEQ 不等于(<>)
GT 大于(>)
EGT 大于等于(>=)
LT 小于(<)
ELT 小于等于(<=)
LIKE 模糊查詢(xún)
[NOT] BETWEEN (不在)區(qū)間查詢(xún)
[NOT] IN (不在)IN 查詢(xún)
EXP 表達(dá)式查詢(xún),支持SQL語(yǔ)法
示例如下:
EQ :等于(=)
例如:
$map['id'] = array('eq',100);
和下面的查詢(xún)等效
$map['id'] = 100;
表示的查詢(xún)條件就是 id = 100
NEQ: 不等于(<>)
例如:
$map['id'] = array('neq',100);
表示的查詢(xún)條件就是 id <> 100
GT:大于(>)
例如:
$map['id'] = array('gt',100);
表示的查詢(xún)條件就是 id > 100
EGT:大于等于(>=)
例如:
$map['id'] = array('egt',100);
表示的查詢(xún)條件就是 id >= 100
LT:小于(<)
例如:
$map['id'] = array('lt',100);
表示的查詢(xún)條件就是 id < 100
ELT: 小于等于(<=)
例如:
$map['id'] = array('elt',100);
表示的查詢(xún)條件就是 id <= 100
[NOT] LIKE: 同sql的LIKE
例如:
$map['name'] = array('like','thinkphp%');
查詢(xún)條件就變成 name like 'thinkphp%'
如果配置了DB_LIKE_FIELDS參數(shù)的話,某些字段也會(huì)自動(dòng)進(jìn)行模糊查詢(xún)。例如設(shè)置了:
'DB_LIKE_FIELDS'=>'title|content'
的話,使用
$map['title'] = 'thinkphp';
查詢(xún)條件就會(huì)變成 name like '%thinkphp%'
支持?jǐn)?shù)組方式,例如
$map['a'] =array('like',array('%thinkphp%','%tp'),'OR');
$map['b'] =array('notlike',array('%thinkphp%','%tp'),'AND');
生成的查詢(xún)條件就是:
(a like '%thinkphp%' OR a like '%tp') AND (b not like '%thinkphp%' AND b not like '%tp')
[NOT] BETWEEN :同sql的[not] between, 查詢(xún)條件支持字符串或者數(shù)組,例如:
$map['id'] = array('between','1,8');
和下面的等效:
$map['id'] = array('between',array('1','8'));
查詢(xún)條件就變成 id BETWEEN 1 AND 8
[NOT] IN: 同sql的[not] in ,查詢(xún)條件支持字符串或者數(shù)組,例如:
$map['id'] = array('not in','1,5,8');
和下面的等效:
$map['id'] = array('not in',array('1','5','8'));
查詢(xún)條件就變成 id NOT IN (1,5, 8)
EXP:表達(dá)式,支持更復(fù)雜的查詢(xún)情況
例如:
$map['id'] = array('in','1,3,8');
可以改成:
$map['id'] = array('exp',' IN (1,3,8) ');
exp查詢(xún)的條件不會(huì)被當(dāng)成字符串,所以后面的查詢(xún)條件可以使用任何SQL支持的語(yǔ)法,包括使用函數(shù)和字段名稱(chēng)。
查詢(xún)表達(dá)式不僅可用于查詢(xún)條件,也可以用于數(shù)據(jù)更新,例如:
$User = M("User"); // 實(shí)例化User對(duì)象
// 要修改的數(shù)據(jù)對(duì)象屬性賦值
$data['name'] = 'ThinkPHP';
$data['score'] = array('exp','score+1');// 用戶(hù)的積分加1
$User->where('id=5')->save($data); // 根據(jù)條件保存修改的數(shù)據(jù)
快捷查詢(xún)
where方法支持快捷查詢(xún)方式,可以進(jìn)一步簡(jiǎn)化查詢(xún)條件的寫(xiě)法,例如:
一、實(shí)現(xiàn)不同字段相同的查詢(xún)條件
$User = M("User"); // 實(shí)例化User對(duì)象
$map['name|title'] = 'thinkphp';
// 把查詢(xún)條件傳入查詢(xún)方法
$User->where($map)->select();
查詢(xún)條件就變成 name= 'thinkphp' OR title = 'thinkphp'
二、實(shí)現(xiàn)不同字段不同的查詢(xún)條件
$User = M("User"); // 實(shí)例化User對(duì)象
$map['status&title'] =array('1','thinkphp','_multi'=>true);
// 把查詢(xún)條件傳入查詢(xún)方法
$User->where($map)->select();
'_multi'=>true必須加在數(shù)組的最后,表示當(dāng)前是多條件匹配,這樣查詢(xún)條件就變成 status= 1 AND title = 'thinkphp' ,查詢(xún)字段支持更多的,例如:
$map['status&score&title'] =array('1',array('gt','0'),'thinkphp','_multi'=>true);
查詢(xún)條件就變成 status= 1 AND score >0 AND title = 'thinkphp'
注意:快捷查詢(xún)方式中“|”和“&”不能同時(shí)使用。
區(qū)間查詢(xún)
where方法支持對(duì)某個(gè)字段的區(qū)間查詢(xún),例如:
$map['id'] = array(array('gt',1),array('lt',10)) ;
得到的查詢(xún)條件是: (`id` > 1) AND (`id` < 10)
$map['id'] = array(array('gt',3),array('lt',10), 'or') ;
得到的查詢(xún)條件是: (`id` > 3) OR (`id` < 10)
$map['id'] = array(array('neq',6),array('gt',3),'and');
得到的查詢(xún)條件是:(`id` != 6) AND (`id` > 3)
最后一個(gè)可以是AND、 OR或者 XOR運(yùn)算符,如果不寫(xiě),默認(rèn)是AND運(yùn)算。
區(qū)間查詢(xún)的條件可以支持普通查詢(xún)的所有表達(dá)式,也就是說(shuō)類(lèi)似LIKE、GT和EXP這樣的表達(dá)式都可以支持。另外區(qū)間查詢(xún)還可以支持更多的條件,只要是針對(duì)一個(gè)字段的條件都可以寫(xiě)到一起,例如:
$map['name'] = array(array('like','%a%'), array('like','%b%'), array('like','%c%'), 'ThinkPHP','or');
最后的查詢(xún)條件是:
(`name` LIKE '%a%') OR (`name` LIKE '%b%') OR (`name` LIKE '%c%') OR (`name` = 'ThinkPHP')
組合查詢(xún)
組合查詢(xún)用于復(fù)雜的查詢(xún)條件,如果你需要在查詢(xún)的時(shí)候同時(shí)偶爾使用字符串卻又不希望丟失數(shù)組方式的靈活的話,可以考慮使用組合查詢(xún)。
組合查詢(xún)的主體還是采用數(shù)組方式查詢(xún),只是加入了一些特殊的查詢(xún)支持,包括字符串模式查詢(xún)(_string)、復(fù)合查詢(xún)(_complex)、請(qǐng)求字符串查詢(xún)(_query),混合查詢(xún)中的特殊查詢(xún)每次查詢(xún)只能定義一個(gè),由于采用數(shù)組的索引方式,索引相同的特殊查詢(xún)會(huì)被覆蓋。
一、字符串模式查詢(xún)(采用_string 作為查詢(xún)條件)
數(shù)組條件還可以和字符串條件混合使用,例如:
$User = M("User"); // 實(shí)例化User對(duì)象
$map['id'] = array('neq',1);
$map['name'] = 'ok';
$map['_string'] = 'status=1 AND score>10';
$User->where($map)->select();
最后得到的查詢(xún)條件就成了:
( `id` != 1 ) AND ( `name` = 'ok' ) AND ( status=1 AND score>10 )
二、請(qǐng)求字符串查詢(xún)方式
請(qǐng)求字符串查詢(xún)是一種類(lèi)似于URL傳參的方式,可以支持簡(jiǎn)單的條件相等判斷。
$map['id'] = array('gt','100');
$map['_query'] = 'status=1&score=100&_logic=or';
得到的查詢(xún)條件是:`id`>100 AND (`status` = '1' OR `score` = '100')
三、復(fù)合查詢(xún)
復(fù)合查詢(xún)相當(dāng)于封裝了一個(gè)新的查詢(xún)條件,然后并入原來(lái)的查詢(xún)條件之中,所以可以完成比較復(fù)雜的查詢(xún)條件組裝。
例如:
$where['name'] = array('like', '%thinkphp%');
$where['title'] = array('like','%thinkphp%');
$where['_logic'] = 'or';
$map['_complex'] = $where;
$map['id'] = array('gt',1);
查詢(xún)條件是
( id > 1) AND ( ( name like '%thinkphp%') OR ( title like '%thinkphp%') )
復(fù)合查詢(xún)使用了_complex作為子查詢(xún)條件來(lái)定義,配合之前的查詢(xún)方式,可以非常靈活的制定更加復(fù)雜的查詢(xún)條件。
很多查詢(xún)方式可以相互轉(zhuǎn)換,例如上面的查詢(xún)條件可以改成:
$where['id'] = array('gt',1);
$where['_string'] = ' (name like "%thinkphp%") OR ( title like "%thinkphp") ';
最后生成的SQL語(yǔ)句是一致的。
多次調(diào)用
3.1.3版本開(kāi)始,where方法支持多次調(diào)用,但字符串條件只能出現(xiàn)一次,例如:
$map['a'] = array('gt',1);
$where['b'] = 1;
$Model->where($map)->where($where)->where('status=1')->select();
多次的數(shù)組條件表達(dá)式會(huì)最終合并,但字符串條件則只支持一次。
關(guān)于ThinkPHP中where()方法的使用,本文就介紹這么多,希望對(duì)您有所幫助