中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

ThinkPHP中where()使用方法詳解
來源:易賢網 閱讀:1711 次 日期:2016-08-26 15:01:46
溫馨提示:易賢網小編為您整理了“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' and

xx='%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 title = 'thinkphp'

二、實現不同字段不同的查詢條件

$User = M("User"); // 實例化User對象

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

// 把查詢條件傳入查詢方法

$User->where($map)->select();

'_multi'=>true必須加在數組的最后,表示當前是多條件匹配,這樣查詢條件就變成 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'

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

區間查詢

where方法支持對某個字段的區間查詢,例如:

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

最后一個可以是AND、 OR或者 XOR運算符,如果不寫,默認是AND運算。

區間查詢的條件可以支持普通查詢的所有表達式,也就是說類似LIKE、GT和EXP這樣的表達式都可以支持。另外區間查詢還可以支持更多的條件,只要是針對一個字段的條件都可以寫到一起,例如:

$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()方法的使用,本文就介紹這么多,希望對您有所幫助

更多信息請查看網絡編程
易賢網手機網站地址:ThinkPHP中where()使用方法詳解
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
91电影在线观看| 欧美一区二区三区在线看| 91首页免费视频| 色呦呦国产精品| 亚洲免费色视频| 亚洲免费成人av| 色婷婷精品大视频在线蜜桃视频 | 一本久道久久综合中文字幕| 久久成人18免费观看| 成人免费一区二区三区在线观看 | 国产精品无遮挡| 亚洲一区二区三区四区在线| 亚洲日本免费电影| 亚洲国产成人91porn| 17c精品麻豆一区二区免费| 久久 天天综合| 欧美大片在线观看| av不卡在线播放| 青青草原综合久久大伊人精品优势 | 国产在线精品一区二区三区不卡| 国产欧美一区二区在线| 欧美色综合久久| 国产成人在线看| 秋霞午夜av一区二区三区| 中文字幕亚洲一区二区va在线| 宅男在线国产精品| 91丨国产丨九色丨pron| 国产激情一区二区三区| 免费看日韩精品| 一区二区三区四区视频精品免费| 亚洲精品在线三区| 欧美精品色综合| 色婷婷一区二区| 不卡一二三区首页| 国产成人精品免费视频网站| 久久电影国产免费久久电影| 日韩和的一区二区| 五月天一区二区三区| 亚洲一二三四久久| 亚洲精品一二三| 亚洲欧美日韩中文字幕一区二区三区 | 亚洲欧美aⅴ...| 欧美激情一区二区三区四区 | 国产成人综合网站| 狠狠色丁香九九婷婷综合五月| 亚洲一二三四区| 亚洲国产乱码最新视频 | 亚洲欧美日韩电影| 亚洲日本va午夜在线影院| 国产精品午夜电影| 国产精品情趣视频| 一区视频在线播放| 亚洲欧美日韩精品久久久久| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 国产亚洲综合av| 国产无遮挡一区二区三区毛片日本| 久久综合色8888| 久久精品一区二区| 日本一二三四高清不卡| 国产精品私人自拍| 亚洲精品欧美综合四区| 亚洲一区二区精品3399| 日韩高清在线不卡| 国内精品国产三级国产a久久| 国产一区二区三区av电影| 国产精品一区免费在线观看| 成人精品视频.| 在线视频国内一区二区| 欧美精品99久久久**| 欧美成人高清电影在线| 国产女人18毛片水真多成人如厕| 成人免费小视频| 天堂成人国产精品一区| 国产一区二区成人久久免费影院| 成人开心网精品视频| 欧美日韩免费电影| 久久久国产精品不卡| 亚洲免费高清视频在线| 老司机免费视频一区二区三区| 国产一区视频导航| 在线精品国精品国产尤物884a| 欧美一区二区三区喷汁尤物| 中文在线一区二区| 琪琪久久久久日韩精品| 成人黄色电影在线| 欧美一区在线视频| 欧美日韩在线观看一区二区| 日韩欧美第一区| 亚洲三级免费电影| 久久99蜜桃精品| 91久久线看在观草草青青| 日韩欧美一卡二卡| 亚洲自拍偷拍欧美| 国产精品66部| 欧美日韩精品免费| 国产精品不卡在线观看| 久国产精品韩国三级视频| 色八戒一区二区三区| 国产校园另类小说区| 日韩精品电影一区亚洲| 91亚洲资源网| 中文字幕 久热精品 视频在线| 日本不卡中文字幕| 在线视频你懂得一区| 国产欧美一区视频| 精品亚洲欧美一区| 欧美放荡的少妇| 亚洲精品欧美在线| 成人激情免费网站| 久久精品亚洲精品国产欧美| 日本色综合中文字幕| 在线观看欧美精品| 亚洲欧美一区二区三区久本道91| 国产一区二区精品久久| 精品福利在线导航| 日韩高清不卡在线| 欧美精品一级二级| 亚洲亚洲人成综合网络| 91成人国产精品| 亚洲蜜臀av乱码久久精品| av一二三不卡影片| 日本一区二区三区四区在线视频| 国内精品久久久久影院薰衣草| 91精品国产高清一区二区三区蜜臀 | 国产成人免费9x9x人网站视频| 欧美一个色资源| 日韩av成人高清| 日韩精品一区二区三区在线观看| 三级影片在线观看欧美日韩一区二区 | 一区二区三区美女| 在线国产电影不卡| 亚洲gay无套男同| 欧美性受xxxx黑人xyx性爽| 亚洲欧美日韩中文播放| 欧美在线影院一区二区| 亚洲第一综合色| 日韩亚洲国产中文字幕欧美| 裸体歌舞表演一区二区| 久久综合网色—综合色88| 日韩高清电影一区| 欧美videossexotv100| 国产一区二区三区在线观看精品| 久久久久久久久久久黄色| 福利一区二区在线| 成人免费在线观看入口| 欧美午夜在线观看| 日韩精品电影一区亚洲| 欧美精品一区二区三区很污很色的 | 久久久久久亚洲综合影院红桃| 国产成人高清在线| 亚洲日本中文字幕区| 欧美唯美清纯偷拍| 经典三级在线一区| 日本一区二区三级电影在线观看| 91视视频在线观看入口直接观看www | 欧美性三三影院| 国内精品久久久久影院薰衣草| 欧美国产日产图区| 欧美色图第一页| 裸体在线国模精品偷拍| 欧美国产一区视频在线观看| 欧美视频一区二区三区四区| 另类综合日韩欧美亚洲| 国产精品乱人伦| 欧美电影在线免费观看| 国产不卡视频一区| 天天射综合影视| 国产免费成人在线视频| 欧美日韩和欧美的一区二区| 高清久久久久久| 日韩国产成人精品| 成人午夜电影小说| 美女视频网站久久| 亚洲精品亚洲人成人网在线播放| 欧美一二区视频| 91电影在线观看| 国产aⅴ综合色| 久久精品国产99国产精品| 亚洲精品高清视频在线观看| 国产调教视频一区| 91精品国产入口| 在线精品观看国产| 不卡的av在线| 国产黄色成人av| 看电影不卡的网站| 亚洲va国产va欧美va观看| 国产精品高潮呻吟| 日韩欧美一级片| 欧美日韩精品久久久| 色8久久精品久久久久久蜜| 国产suv一区二区三区88区| 另类中文字幕网| 亚欧色一区w666天堂| 国产精品美女久久久久久| 久久久五月婷婷| 精品国产精品网麻豆系列 | 91精品综合久久久久久| 色狠狠综合天天综合综合| 国产99一区视频免费| 黄色精品一二区|