thinkphp重點方法詳解之where()方法

where方法的用法是thinkphp查詢語言的精髓,也是thinkphp orm的重要組成部分和亮點所在,可以完成包括普通查詢、表達式查詢、快捷查詢、區間查詢、組合查詢在內的查詢操作。where方法的參數支持字符串和數組,雖然也可以使用對象但并不建議。

字符串條件

$User = M("User"); // 實例化User對象$User->where('type=1 AND status=1')->select();

SELECT * FROM think_user WHERE type=1 AND status=1?

數組條件

普通查詢

$User = M("User");  // 實例化User對象 $map['name'] = 'thinkphp'; $map['status'] = 1;  // 把查詢條件傳入查詢方法 $User->where($map)->select();

SELECT * FROM think_user WHERE `name`=’thinkphp’ AND status=1

表達式查詢

$map['字段1']  = array('表達式','查詢條件1'); $map['字段2']  = array('表達式','查詢條件2'); $Model->where($map)->select();  // 也支持
$map['id']  = array('eq',100);

表示的查詢條件就是 id = 100

$map['id']  = array('neq',100);

表示的查詢條件就是 id 100

立即學習PHP免費學習筆記(深入)”;

$map['id']  = array('gt',100);

表示的查詢條件就是 id > 100

$map['id']  = array('egt',100);

表示的查詢條件就是 id >= 100

$map['id']  = array('lt',100);

表示的查詢條件就是 id

$map['id']  = array('elt',100);

表示的查詢條件就是 id

[NOT] LIKE: 同sql的LIKE

$map['name'] = array('like','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'));

[NOT] IN: 同sql的[not] in ,查詢條件支持字符串或者數組,例如:?

$map['id']  = array('not in','1,5,8');
$map['id']  = array('not in',array('1','5','8'));

EXP:表達式,支持更復雜的查詢情況

$map['id']  = array('exp',' IN (1,3,8) ');

等同于

$map['id']  = array('in','1,3,8');

組合查詢

$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 )?

復合查詢

$where['name']  = array('like', '%thinkphp%'); $where['title']  = array('like','%thinkphp%'); $where['_logic'] = 'or'; $map['_complex'] = $where;$map['id']  = array('gt',1);

等同于

$where['id'] = array('gt',1); $where['_string'] = ' (name like "%thinkphp%")  OR ( title like "%thinkphp") ';

查詢條件是?
(?id?>?1)?AND?( (?name?like?‘%thinkphp%’)?OR?(?title?like?‘%thinkphp%’) )

等等這些都是常用的where查詢方法。

本文轉自TBHacker博客園博客,原文鏈接:http://www.cnblogs.com/jiqing9006/p/4994302.html,如需轉載請自行聯系原作者

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊7 分享