laravel高級的Join語法詳解以及使用Join多個條件
在laravel中我們常常會使用join,leftjion和rightjoin進行連表查詢,非常的方便,但是我今天遇到一個問題,就是鏈表查詢需要on多個條件,即我要訂單的id和發(fā)貨人都一樣,默認的join只支持單個查詢,所以我下面總結(jié)兩種方法:
一、使用原是表達式(不推薦)
原生SQL中我們可以通過如下方法進行
select * from `orders` left join `users` on `orders`.`usename`=`users`.`usename` and `orders`.`platform`=`users`.`platform` where `orders`.`order_status` = 2
那么結(jié)合laravel,我們可以所以
DB::select('select * from `orders` left join `users` on `orders`.`usename`=`users`.`usename` and `orders`.`platform`=`users`.`platform` where `orders`.`order_status` = :id', ['id' => 1]);
二、使用高級的Join語法(推薦使用)
我們只需要所以如下代碼即可完成我們的Join多個條件
DB::table('users') ->join('contacts', function ($join) { $join->on('users.id', '=','contacts.user_id')->on('users.usename', '=','contacts.usename'); }) ->get();
如果你想要了解更多,我們可以看一下文檔中的描述:
讓我們以傳入一個閉包當作 join 方法的第二參數(shù)來作為開始。此閉包會接收 JoinClause 對象,讓你可以在 join 子句上指定約束:
DB::table('users') ->join('contacts', function ($join) { $join->on('users.id', '=','contacts.user_id')->orOn(...); }) ->get();
若你想要在連接中使用「where」風格的子句,則可以在連接中使用 where 和 orWhere 方法。這些方法會比較字段和一個值,來代替兩個字段的比較:
DB::table('users') ->join('contacts', function ($join) { $join->on('users.id', '=', 'contacts.user_id') ->where('contacts.user_id', '>', 5); }) ->get();
以上這篇laravel高級的Join語法詳解以及使用Join多個條件就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
thinkPHP簡單調(diào)用函數(shù)與類庫的方法
這篇文章主要介紹了thinkPHP簡單調(diào)用函數(shù)與類庫的方法,簡單講述了thinkPHP公共函數(shù)庫的文件位置并結(jié)合實例分析了類庫的調(diào)用方法,需要的朋友可以參考下2017-03-03PHP網(wǎng)頁游戲?qū)W習之Xnova(ogame)源碼解讀(四)
這篇文章主要介紹了PHP網(wǎng)頁游戲Xnova(ogame)源碼解讀的用戶登錄頁面,需要的朋友可以參考下2014-06-06如何使用php腳本給html中引用的js和css路徑打上版本號
這篇文章主要介紹了如何使用php腳本給html中引用的js和css路徑打上版本號,打版本號有個好處就是可以解決外部應(yīng)用文件實時更新問題,喜歡的朋友一起看看全文吧2015-11-11CodeIgniter實現(xiàn)從網(wǎng)站抓取圖片并自動下載到文件夾里的方法
這篇文章主要介紹了CodeIgniter實現(xiàn)從網(wǎng)站抓取圖片并自動下載到文件夾里的方法,實例分析了CodeIgniter網(wǎng)頁圖片操作的相關(guān)技巧,需要的朋友可以參考下2015-06-06