亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

ThinkPHP中where()使用方法詳解

2024-05-04 23:45:06
字體:
來源:轉載
供稿:網友
where方法可以用于對數據庫操作的結果進行篩選。即SQL查詢語句中的where子句。本文給大家介紹ThinkPHP中where()使用方法詳解,感興趣的朋友參考下
 

本文介紹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(); 

'_multi'=>true必須加在數組的最后,表示當前是多條件匹配,這樣查詢條件就變成 status= 1 AND style="margin: 0px; padding: 0px; line-height: 25.2px; width: 660px; overflow: hidden; clear: both;">

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

查詢條件就變成 status= 1 AND score >0 AND style="margin: 0px; padding: 0px; line-height: 25.2px; width: 660px; overflow: hidden; clear: both;">

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

組合查詢

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

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

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

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

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

二、請求字符串查詢方式

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

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

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

三、復合查詢

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

$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%') )

復合查詢使用了_complex作為子查詢條件來定義,配合之前的查詢方式,可以非常靈活的制定更加復雜的查詢條件。

很多查詢方式可以相互轉換,例如上面的查詢條件可以改成:

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

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

多次調用

3.1.3版本開始,where方法支持多次調用,但字符串條件只能出現一次,例如:

$map['a'] = array('gt',1);$where['b'] = 1;$Model->where($map)->where($where)->where('status=1')->select();

多次的數組條件表達式會最終合并,但字符串條件則只支持一次。

關于ThinkPHP中where()方法的使用,本文就介紹這么多,希望對您有所幫助,謝謝!



注:相關教程知識閱讀請移步到PHP教程頻道。
上一篇:ThinkPHP中limit()使用方法詳解

下一篇:yii2整合百度編輯器umeditor及umeditor圖片上傳問題的解決辦法

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片
猜你喜歡的新聞
猜你喜歡的關注

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线播放日韩欧美| 亚洲最大成人免费视频| 精品福利在线视频| 国产精品久久久久福利| 精品国偷自产在线视频99| 欧美激情欧美激情| 国产亚洲精品久久| 97久久精品人搡人人玩| 97精品国产97久久久久久免费| 欧美性猛交xxxx乱大交3| 最近2019中文免费高清视频观看www99| 国产九九精品视频| 97av在线视频免费播放| 欧美亚洲国产视频小说| 国产精品久久久久77777| 亚洲第一色在线| 色悠悠久久久久| 亚洲国产91精品在线观看| 国产这里只有精品| 国产成人精品久久二区二区91| 91精品国产高清久久久久久91| 中文字幕在线日韩| 亚洲午夜精品视频| 日韩不卡中文字幕| 伊人久久久久久久久久久| 理论片在线不卡免费观看| 中文字幕在线国产精品| 亚洲精品成a人在线观看| 懂色av中文一区二区三区天美| 亚洲欧美综合精品久久成人| 日韩在线观看免费高清| 色综合久久久久久中文网| 午夜精品视频在线| 欧美激情xxxx| 欧洲成人免费aa| 91沈先生作品| 国产成人精品久久| 欧美裸体视频网站| 久久久成人的性感天堂| 欧美日韩福利视频| 亚洲一级黄色片| 精品一区精品二区| 亚洲成年人在线播放| 亚洲精品中文字幕有码专区| 亚洲成人av资源网| 美女撒尿一区二区三区| 色一区av在线| 国产一级揄自揄精品视频| 日韩精品在线视频美女| 日本免费一区二区三区视频观看| 中文欧美日本在线资源| 亚洲高清一二三区| 555www成人网| 青青久久av北条麻妃黑人| 欧美一区二区三区精品电影| 亚洲高清福利视频| 亚洲国产99精品国自产| 日韩一二三在线视频播| 欧美另类极品videosbestfree| 亚洲国产精久久久久久久| 中文字幕精品一区久久久久| 丝袜美腿精品国产二区| 69影院欧美专区视频| 91午夜理伦私人影院| 国产精品久久久久久婷婷天堂| 亚洲国产精品久久久久久| 日韩av成人在线观看| 中日韩美女免费视频网址在线观看| 国模视频一区二区三区| 亚洲精品国产福利| 国产一区红桃视频| 亚洲国产欧美一区二区三区同亚洲| 国产精品久久久久999| 久久九九有精品国产23| 欧美整片在线观看| 国产视频亚洲精品| 欧美一级大片在线免费观看| 日韩电影中文字幕av| 九九热视频这里只有精品| 欧洲永久精品大片ww免费漫画| 日韩av大片在线| 日韩av在线资源| 亚洲va欧美va国产综合久久| 日韩精品www| 亚洲精品成人久久电影| 国产精品自拍视频| 欧美性xxxx在线播放| 91成人在线观看国产| 国产精品99免视看9| 久久久这里只有精品视频| 国内精品模特av私拍在线观看| 日韩高清电影好看的电视剧电影| 色综合影院在线| 欧美激情亚洲自拍| 欧美黑人性生活视频| 最好看的2019年中文视频| 国产精品99久久久久久www| 国模吧一区二区| 日韩欧美国产激情| 全色精品综合影院| 在线日韩日本国产亚洲| 两个人的视频www国产精品| www高清在线视频日韩欧美| 91国产一区在线| 亚洲国产精品久久| 久久中文字幕在线| 欧美激情亚洲自拍| 国产日韩欧美在线观看| 欧美黑人性猛交| 国产精品永久在线| 亚洲人免费视频| 久久精品久久久久久| 91久久精品久久国产性色也91| 97精品一区二区视频在线观看| 91精品视频免费观看| 一夜七次郎国产精品亚洲| 日韩大片在线观看视频| 性欧美xxxx视频在线观看| 亚洲综合自拍一区| 久久久久久久久久久91| 日韩视频免费中文字幕| 国产精品女人久久久久久| 国产精品人成电影| 亚洲自拍偷拍第一页| 97在线视频免费看| 欧美洲成人男女午夜视频| 欧美国产亚洲精品久久久8v| 欧美激情a∨在线视频播放| 狠狠躁天天躁日日躁欧美| 欧美放荡办公室videos4k| 国产欧美精品一区二区三区-老狼| 亚洲精品久久久久久久久| 久久久国产精品x99av| 97av视频在线| 另类天堂视频在线观看| 欧美www在线| 精品欧美国产一区二区三区| 91网站在线免费观看| 日韩免费看的电影电视剧大全| 欧美美女18p| 深夜福利亚洲导航| 4k岛国日韩精品**专区| 日韩av黄色在线观看| 国产一区二区在线免费视频| 成人黄色av播放免费| 日韩av免费在线观看| 精品露脸国产偷人在视频| 色婷婷**av毛片一区| 免费99精品国产自在在线| 亚洲视频第一页| 国产精品成人国产乱一区| 日韩在线免费观看视频| 国产丝袜一区二区三区免费视频| 国产精品九九久久久久久久| 国产亚洲xxx| 久热在线中文字幕色999舞| 亚洲三级黄色在线观看| 日韩精品免费看| 国产欧美日韩中文字幕| 亚洲人午夜精品| 久久久成人精品视频| 日本久久久久久久久久久| 国产精品旅馆在线| 精品视频久久久久久久|