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