本文介紹ThinkPHP的where()方法的用法。where方法可以用于對數據庫操作的結果進行篩選。即SQL查詢語句中的where子句。
今天來給大家講下查詢最常用但也是最復雜的where方法,where方法也屬于模型類的連貫操作方法之一,主要用于查詢和操作條件的設置。
where方法的用法是ThinkPHP查詢語言的精髓,也是ThinkPHP ORM的重要組成部分和亮點所在,可以完成包括普通查詢、表達式查詢、快捷查詢、區間查詢、組合查詢在內的查詢操作。where方法的參數支持字符串和數組,雖然也可以使用對象但并不建議。
字符串條件
使用字符串條件直接查詢和操作,例如:
$User = M("User"); // 實例化User對象$User->where('type=1 AND status=1')->select();
最后生成的SQL語句是
SELECT * FROM think_user WHERE type=1 AND status=1
如果使用3.1以上版本的話,使用字符串條件的時候,建議配合預處理機制,確保更加安全,例如:
$Model->where("id=%d and username='%s' andxx='%f'",array($id,$username,$xx))->select();
或者使用:
$Model->where("id=%d and username='%s' and xx='%f'",$id,$username,$xx)->select();
如果$id變量來自用戶提交或者URL地址的話,如果傳入的是非數字類型,則會強制格式化為數字格式后進行查詢操作。
字符串預處理格式類型支持指定數字、字符串等,具體可以參考vsprintf方法的參數說明。
數組條件
數組條件的where用法是ThinkPHP推薦的用法。
普通查詢
最簡單的數組查詢方式如下:
$User = M("User"); // 實例化User對象$map['name'] = 'thinkphp';$map['status'] = 1;// 把查詢條件傳入查詢方法$User->where($map)->select();
最后生成的SQL語句是
SELECT * FROM think_user WHERE `name`='thinkphp' AND status=1
表達式查詢
上面的查詢條件僅僅是一個簡單的相等判斷,可以使用查詢表達式支持更多的SQL查詢語法,查詢表達式的使用格式:
$map['字段1'] = array('表達式','查詢條件1');$map['字段2'] = array('表達式','查詢條件2');$Model->where($map)->select(); // 也支持
表達式不分大小寫,支持的查詢表達式有下面幾種,分別表示的含義是:
表達式 含義
EQ 等于(=)
NEQ 不等于(<>)
GT 大于(>)
EGT 大于等于(>=)
LT 小于(<)
ELT 小于等于(<=)
LIKE 模糊查詢
[NOT] BETWEEN (不在)區間查詢
[NOT] IN (不在)IN 查詢
EXP 表達式查詢,支持SQL語法
示例如下:
EQ :等于(=)
例如:
$map['id'] = array('eq',100);
和下面的查詢等效
$map['id'] = 100;
表示的查詢條件就是 id = 100
NEQ: 不等于(<>)
例如:
$map['id'] = array('neq',100);
表示的查詢條件就是 id <> 100
GT:大于(>)
例如:
$map['id'] = array('gt',100);
表示的查詢條件就是 id > 100
EGT:大于等于(>=)
例如:
$map['id'] = array('egt',100);
表示的查詢條件就是 id >= 100
LT:小于(<)
例如:
$map['id'] = array('lt',100);
表示的查詢條件就是 id < 100
ELT: 小于等于(<=)
例如:
$map['id'] = array('elt',100);
表示的查詢條件就是 id <= 100
[NOT] LIKE: 同sql的LIKE
例如:
$map['name'] = array('like','thinkphp%');
查詢條件就變成 name like 'thinkphp%'
如果配置了DB_LIKE_FIELDS參數的話,某些字段也會自動進行模糊查詢。例如設置了:
'DB_LIKE_FIELDS'=>'title|content'
的話,使用
$map['title'] = 'thinkphp';
查詢條件就會變成 name like '%thinkphp%'
支持數組方式,例如
$map['a'] =array('like',array('%thinkphp%','%tp'),'OR');$map['b'] =array('notlike',array('%thinkphp%','%tp'),'AND');
生成的查詢條件就是:
(a like '%thinkphp%' OR a like '%tp') AND (b not like '%thinkphp%' AND b not like '%tp')
[NOT] BETWEEN :同sql的[not] between, 查詢條件支持字符串或者數組,例如:
$map['id'] = array('between','1,8');
和下面的等效:
$map['id'] = array('between',array('1','8'));
查詢條件就變成 id BETWEEN 1 AND 8
[NOT] IN: 同sql的[not] in ,查詢條件支持字符串或者數組,例如:
$map['id'] = array('not in','1,5,8');
和下面的等效:
$map['id'] = array('not in',array('1','5','8'));
查詢條件就變成 id NOT IN (1,5, 8)
EXP:表達式,支持更復雜的查詢情況
例如:
$map['id'] = array('in','1,3,8');
可以改成:
$map['id'] = array('exp',' IN (1,3,8) ');
exp查詢的條件不會被當成字符串,所以后面的查詢條件可以使用任何SQL支持的語法,包括使用函數和字段名稱。
查詢表達式不僅可用于查詢條件,也可以用于數據更新,例如:
$User = M("User"); // 實例化User對象// 要修改的數據對象屬性賦值$data['name'] = 'ThinkPHP';$data['score'] = array('exp','score+1');// 用戶的積分加1$User->where('id=5')->save($data); // 根據條件保存修改的數據
快捷查詢
where方法支持快捷查詢方式,可以進一步簡化查詢條件的寫法,例如:
一、實現不同字段相同的查詢條件
$User = M("User"); // 實例化User對象$map['name|title'] = 'thinkphp';// 把查詢條件傳入查詢方法$User->where($map)->select();
查詢條件就變成 name= 'thinkphp' OR style="margin: 0px; padding: 0px; line-height: 25.2px; width: 660px; overflow: hidden; clear: both;">
$User = M("User"); // 實例化User對象$map['status&title'] =array('1','thinkphp','_multi'=>true);// 把查詢條件傳入查詢方法$User->where($map)->select();