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

首頁 > 編程 > PHP > 正文

ThinkPHP CURD方法之where方法詳解

2020-03-22 20:28:13
字體:
來源:轉載
供稿:網友
ThinkPHP CURD操作的查詢方法中最常用但也是最復雜的就是where方法。where方法也屬于模型類的連貫操作方法之一,主要用于查詢和操作條件的設置。where方法的用法是ThinkPHP查詢語言的精髓,也是ThinkPHP ORM(對象關系映射)的重要組成部分和亮點所在,可以完成包括普通查詢、表達式查詢、快捷查詢、區間查詢、組合查詢在內的查詢操作。where方法的參數支持字符串和數組,雖然也可以使用對象但并不建議。1.字符串條件使用字符串條件直接查詢和操作,例如:$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方法的參數說明。2.數組條件數組條件的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(); // 也支持表達式不分大小寫,支持的查詢表達式有下面幾種,分別表示的含義是:

查詢條件就變成 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 $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.多次調用自3.1.3版本開始,where方法支持多次調用,但字符串條件只能出現一次,例如:$map['a'] = array('gt',1);$where['b'] = 1;$Model- where($map)- where($where)- where('status=1')- select();多次的數組條件表達式會最終合并,但字符串條件則只支持一次。PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美中文在线视频| 日韩欧美亚洲一二三区| 日韩在线观看免费全集电视剧网站| 亚洲护士老师的毛茸茸最新章节| 欧美激情第1页| 精品国产户外野外| 欧美视频在线观看 亚洲欧| 亚洲风情亚aⅴ在线发布| 国产精品极品美女在线观看免费| 97视频在线观看亚洲| 97国产精品视频人人做人人爱| 日本一区二区三区四区视频| 中文字幕亚洲综合| 欧美乱人伦中文字幕在线| 亚洲国产精品一区二区久| 亚洲免费福利视频| 555www成人网| 欧美成年人视频| 岛国视频午夜一区免费在线观看| 久久在精品线影院精品国产| 精品视频在线播放免| 成人伊人精品色xxxx视频| 九九精品在线视频| 久久综合久中文字幕青草| 国产日本欧美一区二区三区在线| 久久精品国产69国产精品亚洲| 亚洲欧美另类自拍| 国内免费久久久久久久久久久| 欧美第一黄网免费网站| 亚洲新中文字幕| 成人写真视频福利网| 91在线视频九色| 成人国产精品一区| 精品日本美女福利在线观看| 九九久久国产精品| 色悠悠久久久久| 亚洲色图日韩av| 精品激情国产视频| 久久久久久久久久婷婷| 久久精品国产免费观看| 91网站在线免费观看| 亚洲国产成人在线播放| 亚洲国产精彩中文乱码av在线播放| 亚洲国产日韩精品在线| 国产精品嫩草影院一区二区| 伊人久久久久久久久久久| 久久久久久久影视| 青青草精品毛片| 国产精品黄色av| 精品久久久中文| 亚洲欧美日韩区| 精品国产视频在线| 日韩在线精品视频| 中文字幕久精品免费视频| 国产性猛交xxxx免费看久久| 久久久久久国产精品久久| 欧美午夜宅男影院在线观看| 亚洲一区二区在线| 成人h片在线播放免费网站| 日本韩国在线不卡| 亚州成人av在线| 国产三级精品网站| 一区二区三区国产在线观看| 亚洲美女久久久| 精品国产一区二区三区久久狼5月| 精品久久久久久亚洲国产300| 欧美极品少妇与黑人| 97国产成人精品视频| 欧美性猛交xxxx黑人猛交| 亚洲品质视频自拍网| 亚洲国产精品女人久久久| 国产视频999| 中文字幕日韩免费视频| 91色精品视频在线| 久久久久久国产精品美女| 国产精品第1页| 国产精品入口夜色视频大尺度| 91人成网站www| 国产精品自产拍在线观| 久久精品国产v日韩v亚洲| 久久精品中文字幕免费mv| 91精品国产沙发| 欧美一区二区三区……| 亚洲丝袜在线视频| 国产精品久久久久久久久久久久久| 欧美激情精品久久久久久久变态| 黑人精品xxx一区| 亚洲精品免费一区二区三区| 欧美精品在线免费观看| 亚洲视频欧美视频| 亚洲人成在线免费观看| 国产69久久精品成人| 欧美多人爱爱视频网站| xxxx欧美18另类的高清| 538国产精品视频一区二区| 色老头一区二区三区在线观看| 久久天堂电影网| 久久亚洲私人国产精品va| 日韩欧美成人精品| 久久久精品网站| 亚洲欧美国产精品| 欧美日本在线视频中文字字幕| 国产91精品久| 国内精品国产三级国产在线专| 亚洲va久久久噜噜噜| 国产精品激情av电影在线观看| 91久久国产精品| 深夜福利亚洲导航| 国产精品日韩在线| 91精品久久久久久久久久入口| 色综合久久88| 国内精品视频一区| 国产精品人成电影在线观看| 一区二区三区国产在线观看| xxxxx91麻豆| 亚洲男女性事视频| 亚洲一区亚洲二区| 亚洲最大的网站| 91九色国产社区在线观看| 美女扒开尿口让男人操亚洲视频网站| 日韩欧美中文字幕在线播放| 欧美在线一区二区视频| 欧美成人午夜激情在线| 国产精品一区二区三区久久久| 欧美视频裸体精品| 在线观看国产精品日韩av| 成人精品一区二区三区电影黑人| 亚洲最大的av网站| 68精品国产免费久久久久久婷婷| 日韩午夜在线视频| 久久亚洲精品中文字幕冲田杏梨| 日韩精品视频免费| 精品日韩视频在线观看| 一区二区在线视频| 青青草一区二区| 久久久免费观看视频| 国产裸体写真av一区二区| 日日噜噜噜夜夜爽亚洲精品| 日韩人体视频一二区| 欧美成人精品xxx| 日韩大片免费观看视频播放| 91av福利视频| 热99在线视频| 久久久久久久爱| 在线视频日本亚洲性| 日韩在线中文字幕| 亚洲男人天堂古典| 疯狂蹂躏欧美一区二区精品| 国产精品久久久久久一区二区| 国产视频精品一区二区三区| 久久精品视频在线播放| 久久天天躁狠狠躁夜夜av| 成人网中文字幕| 亚洲精品视频播放| 国产日本欧美一区二区三区在线| 国产精品久久久久久亚洲影视| 亚洲自拍小视频免费观看| 久久资源免费视频| 精品久久久久久| 日韩av在线导航| 欧美国产日产韩国视频| 亚洲高清免费观看高清完整版| 亚洲欧美在线一区| 欧美午夜片在线免费观看|