一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

ThinkPHP CURD方法之where方法詳解

Thinkphp CURD操作的查詢方法中最常用但也是最復(fù)雜的就是where方法。where方法也屬于模型類的連貫操作方法之一,主要用于查詢和操作條件的設(shè)置。

where方法的用法是Thinkphp查詢語言的精髓,也是Thinkphp ORM(對象關(guān)系映射)的重要組成部分和亮點(diǎn)所在,可以完成包括普通查詢、表達(dá)式查詢、快捷查詢、區(qū)間查詢、組合查詢在內(nèi)的查詢操作。where方法的參數(shù)支持字符串和數(shù)組,雖然也可以使用對象但并不建議。

1.字符串條件

使用字符串條件直接查詢和操作,例如:

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

最后生成的SQL語句是

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變量來自用戶提交或者URL地址的話,如果傳入的是非數(shù)字類型,則會(huì)強(qiáng)制格式化為數(shù)字格式后進(jìn)行查詢操作。
字符串預(yù)處理格式類型支持指定數(shù)字、字符串等,具體可以參考vsprintf方法的參數(shù)說明。

2.數(shù)組條件

數(shù)組條件的where用法是Thinkphp推薦的用法。

普通查詢

最簡單的數(shù)組查詢方式如下:

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

最后生成的SQL語句是

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

表達(dá)式查詢

上面的查詢條件僅僅是一個(gè)簡單的相等判斷,可以使用查詢表達(dá)式支持更多的SQL查詢語法,查詢表達(dá)式的使用格式:

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

表達(dá)式不分大小寫,支持的查詢表達(dá)式有下面幾種,分別表示的含義是:

表達(dá)式 含義
EQ 等于(=)
NEQ 不等于(<>)
GT 大于(>)
EGT 大于等于(>=)
LT 小于(<)
ELT 小于等于(<=)
LIKE 模糊查詢
[NOT] BETWEEN (不在)區(qū)間查詢
[NOT] IN (不在)IN 查詢
EXP 表達(dá)式查詢,支持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參數(shù)的話,某些字段也會(huì)自動(dòng)進(jìn)行模糊查詢。例如設(shè)置了:

'DB_LIKE_FIELDS'=>'title|content'

的話,使用

$map['title'] = 'thinkphp';

查詢條件就會(huì)變成 name like '%thinkphp%'
支持?jǐn)?shù)組方式,例如

$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, 查詢條件支持字符串或者數(shù)組,例如:

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

和下面的等效:

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

查詢條件就變成 id BETWEEN 1 AND 8

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

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

和下面的等效:

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

查詢條件就變成 id NOT IN (1,5, 8)

EXP:表達(dá)式,支持更復(fù)雜的查詢情況

例如:

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

可以改成:

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

exp查詢的條件不會(huì)被當(dāng)成字符串,所以后面的查詢條件可以使用任何SQL支持的語法,包括使用函數(shù)和字段名稱。

查詢表達(dá)式不僅可用于查詢條件,也可以用于數(shù)據(jù)更新,例如:

$User = M("User"); // 實(shí)例化User對象 // 要修改的數(shù)據(jù)對象屬性賦值$data['name'] = 'Thinkphp';$data['score'] = array('exp','score+1');// 用戶的積分加1$User->where('id=5')->save($data); // 根據(jù)條件保存修改的數(shù)據(jù)

快捷查詢

where方法支持快捷查詢方式,可以進(jìn)一步簡化查詢條件的寫法,例如:

一、實(shí)現(xiàn)不同字段相同的查詢條件

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

查詢條件就變成 name= 'thinkphp' OR title = 'thinkphp'

二、實(shí)現(xiàn)不同字段不同的查詢條件

$User = M("User"); // 實(shí)例化User對象$map['status&title'] =array('1','thinkphp','_multi'=>true); // 把查詢條件傳入查詢方法$User->where($map)->select(); 

'_multi'=>true必須加在數(shù)組的最后,表示當(dāng)前是多條件匹配,這樣查詢條件就變成 status= 1 AND title = 'thinkphp' ,查詢字段支持更多的,例如:

$map['status&score&title'] =array('1',array('gt','0'),'thinkphp','_multi'=>true);

查詢條件就變成 status= 1 AND score >0 AND title = 'thinkphp'

注意:快捷查詢方式中“|”和“&”不能同時(shí)使用。

區(qū)間查詢

where方法支持對某個(gè)字段的區(qū)間查詢,例如:

$map['id'] = array(array('gt',1),array('lt',10)) ;

得到的查詢條件是: (`id` > 1) AND (`id` < 10)

$map['id'] = array(array('gt',3),array('lt',10), 'or') ;

得到的查詢條件是: (`id` > 3) OR (`id` < 10)

$map['id'] = array(array('neq',6),array('gt',3),'and'); 

得到的查詢條件是:(`id` != 6) AND (`id` > 3)

最后一個(gè)可以是AND、 OR或者 XOR運(yùn)算符,如果不寫,默認(rèn)是AND運(yùn)算。
區(qū)間查詢的條件可以支持普通查詢的所有表達(dá)式,也就是說類似LIKE、GT和EXP這樣的表達(dá)式都可以支持。另外區(qū)間查詢還可以支持更多的條件,只要是針對一個(gè)字段的條件都可以寫到一起,例如:

$map['name'] = array(array('like','%a%'), array('like','%b%'), array('like','%c%'), 'Thinkphp','or'); 

最后的查詢條件是:

(`name` LIKE '%a%') OR (`name` LIKE '%b%') OR (`name` LIKE '%c%') OR (`name` = 'Thinkphp')

組合查詢

組合查詢用于復(fù)雜的查詢條件,如果你需要在查詢的時(shí)候同時(shí)偶爾使用字符串卻又不希望丟失數(shù)組方式的靈活的話,可以考慮使用組合查詢。

組合查詢的主體還是采用數(shù)組方式查詢,只是加入了一些特殊的查詢支持,包括字符串模式查詢(_string)、復(fù)合查詢(_complex)、請求字符串查詢(_query),混合查詢中的特殊查詢每次查詢只能定義一個(gè),由于采用數(shù)組的索引方式,索引相同的特殊查詢會(huì)被覆蓋。

一、字符串模式查詢(采用_string 作為查詢條件)

數(shù)組條件還可以和字符串條件混合使用,例如:

$User = M("User"); // 實(shí)例化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 )

二、請求字符串查詢方式

請求字符串查詢是一種類似于URL傳參的方式,可以支持簡單的條件相等判斷。

$map['id'] = array('gt','100');$map['_query'] = 'status=1&score=100&_logic=or';

得到的查詢條件是:`id`>100 AND (`status` = '1' OR `score` = '100')

三、復(fù)合查詢

復(fù)合查詢相當(dāng)于封裝了一個(gè)新的查詢條件,然后并入原來的查詢條件之中,所以可以完成比較復(fù)雜的查詢條件組裝。
例如:

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

查詢條件是

( id > 1) AND ( ( name like '%thinkphp%') OR ( title like '%thinkphp%') )

復(fù)合查詢使用了_complex作為子查詢條件來定義,配合之前的查詢方式,可以非常靈活的制定更加復(fù)雜的查詢條件。
很多查詢方式可以相互轉(zhuǎn)換,例如上面的查詢條件可以改成:

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

最后生成的SQL語句是一致的。

3.多次調(diào)用

自3.1.3版本開始,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ì)最終合并,但字符串條件則只支持一次。

php技術(shù)ThinkPHP CURD方法之where方法詳解,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 九九啪| 亚洲一卡2卡4卡5卡6卡在线99 | 中文字幕一视频97色伦 | 午夜免费视频网站 | 国产精品一区在线免费观看 | 色草在线 | 国产精品嫩草影院在线观看免费 | 亚洲人成网77777亚洲 | 欧美成人久久久 | 日韩中文字幕久久久经典网 | 中文字幕精品一区二区三区视频 | 99午夜| 亚洲精品国产福利在线观看 | h片视频在线观看 | 亚洲图片在线 | www.五月| 亚洲婷婷综合色高清在线 | 国产原创视频 | 久久久这里有精品 | 99色网站| 天天做天天玩天天爽天天 | 超级97人人公开视频 | 在线a亚洲视频播放在线观看 | 亚洲欧美在线精品一区二区 | 亚洲欧美人妖另类激情综合区 | 在线看黄网址 | 久久久噜噜噜久久中文字幕色伊伊 | 精品久久久久久免费影院 | 久久精品国产91久久麻豆自制 | 亚洲人人爱 | v视界影院视频一区二区三区 | 欧美黑人巨大xxxxxfreexxxxx | 97久久精品国产成人影院 | 国产精品久久久久久麻豆一区 | 激情小说 激情图片 | 亚洲黄色免费观看 | 国产欧美一级片 | 91草莓视频在线观看 | 最新eeuss影院在线观看 | 欧美日韩一区二区三 | 国产精品午夜在线观看 |