首頁 >php框架 >ThinkPHP >thinkphp重點方法詳解之where()方法

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

藏色散人
藏色散人轉載
2021-12-09 16:43:014068瀏覽

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

$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,如需转载请自行联系原作者

以上是thinkphp重點方法詳解之where()方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除