thinkphp中的多表關聯(lián)查詢的實例詳解
在進行后端管理系統(tǒng)的編程的時候一般會使用框架來進行頁面的快速搭建,我最近使用比較多的就是thinkphp框架,thinkphp框架的應用其實就是把前端和后端進行分割管理,前端用戶登錄查詢系統(tǒng)放在thinkphp中的home文件夾中進行管理,后端管理系統(tǒng)放在thinkphp中的admin文件夾中進行管理。對了,在使用thinkphp框架的時候是是要用到mvc架構的,mvc架構就是model(數(shù)據(jù)模型)、view(視圖)、controller(控制器)的結構,這里界面是由視圖來進行控制,控制器的作用就是管理視圖和控制器,詳細的結構可以查詢thinkphp的文檔進行學習。
今天要說的就是在后端管理系統(tǒng)中遇到的數(shù)據(jù)庫表的關聯(lián)查詢應用。
首先要說的就是在thinkphp中的查詢語句的應用,當然這里并不是簡單的對一個數(shù)據(jù)表的查詢工作,而是進行多表之間的關聯(lián)查詢,這里面進行數(shù)據(jù)的關聯(lián)有兩種方法join和table方法 。
1、首先介紹的是table方法進行多表之間的關聯(lián)查詢
最前面的M是thinkphp中的M模型,作用就是選擇數(shù)據(jù)庫中的數(shù)據(jù)表,table中選擇的是要關聯(lián)的哪些表,where是進行條件關聯(lián),field的作用其實就是一個過濾作用,可以把你想要的或者有用的信息輸出出來,這樣對表進行關聯(lián)之后的結果就是剩下自己想要的數(shù)據(jù)結構了。
public function orderList(){
$User=M("t_order");
/*兩個表的關聯(lián)查詢得到等級值*/
$userinfo = $User->table('t_order,t_commodity,t_user')->where('t_order.cname = t_commodity.cname and t_order.uname = t_user.uname ')->field('t_order_id,t_order.orderid,t_order.cname')->select();
$this->assign("userInfo",$userinfo);
$this->display("order-list");
}
2、join方法進行多表之間的關聯(lián)查詢
這里面的表的關聯(lián)的區(qū)別就是join使用了on來進行表的關聯(lián),剩下的部分其實就是一樣,where中是關聯(lián)的條件,field中是過濾的信息(對接下來有用的信息)
public function getBanner(){
$bannerid=1;
$banner=M("banner_item");
$result=$banner->join('image ON banner_item.img_id = image.id')->where("banner_item.banner_id=".$bannerid)->field("key_word,type,banner_id,url,from")->select();
echo json_encode($result);
}
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
您可能感興趣的文章:- thinkphp學習筆記之多表查詢
- thinkphp中多表查詢中防止數(shù)據(jù)重復的sql語句(必看)
- thinkphp多表查詢兩表有重復相同字段的完美解決方法
- thinkPHP多表查詢及分頁功能實現(xiàn)方法示例
- ThinkPHP多表聯(lián)合查詢的常用方法
- thinkphp實現(xiàn)like模糊查詢實例
- ThinkPHP查詢語句與關聯(lián)查詢用法實例
- ThinkPHP視圖查詢詳解
- ThinkPHP中的常用查詢語言匯總
- thinkPHP框架實現(xiàn)多表查詢的方法