laravel高級(jí)的Join語(yǔ)法詳解以及使用Join多個(gè)條件
在laravel中我們常常會(huì)使用join,leftjion和rightjoin進(jìn)行連表查詢,非常的方便,但是我今天遇到一個(gè)問題,就是鏈表查詢需要on多個(gè)條件,即我要訂單的id和發(fā)貨人都一樣,默認(rèn)的join只支持單個(gè)查詢,所以我下面總結(jié)兩種方法:
一、使用原是表達(dá)式(不推薦)
原生SQL中我們可以通過如下方法進(jìn)行
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]);
二、使用高級(jí)的Join語(yǔ)法(推薦使用)
我們只需要所以如下代碼即可完成我們的Join多個(gè)條件
DB::table('users')
->join('contacts', function ($join) {
$join->on('users.id', '=','contacts.user_id')->on('users.usename', '=','contacts.usename');
})
->get();
如果你想要了解更多,我們可以看一下文檔中的描述:
讓我們以傳入一個(gè)閉包當(dāng)作 join 方法的第二參數(shù)來作為開始。此閉包會(huì)接收 JoinClause 對(duì)象,讓你可以在 join 子句上指定約束:
DB::table('users')
->join('contacts', function ($join) {
$join->on('users.id', '=','contacts.user_id')->orOn(...);
})
->get();
若你想要在連接中使用「where」風(fēng)格的子句,則可以在連接中使用 where 和 orWhere 方法。這些方法會(huì)比較字段和一個(gè)值,來代替兩個(gè)字段的比較:
DB::table('users')
->join('contacts', function ($join) {
$join->on('users.id', '=', 'contacts.user_id')
->where('contacts.user_id', '>', 5);
})
->get();
以上這篇laravel高級(jí)的Join語(yǔ)法詳解以及使用Join多個(gè)條件就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
CI框架教程之優(yōu)化驗(yàn)證碼機(jī)制詳解【驗(yàn)證碼輔助函數(shù)】
這篇文章主要介紹了CI框架教程之優(yōu)化驗(yàn)證碼機(jī)制,結(jié)合實(shí)例形式詳細(xì)分析了CodeIgniter框架驗(yàn)證碼輔助函數(shù)相關(guān)使用及優(yōu)化操作技巧,需要的朋友可以參考下2019-04-04
Laravel 中使用簡(jiǎn)單的方法跟蹤用戶是否在線(推薦)
最近小編在做一個(gè)需求,需要在Laravel應(yīng)用程序用戶個(gè)人資料頁(yè)面上,用戶名旁邊添加一個(gè)綠點(diǎn),表示他們是否在線。下面小編給大家?guī)硪环N簡(jiǎn)單方法實(shí)現(xiàn)Laravel 跟蹤用戶是否在線,感興趣的朋友一起看看吧2019-10-10
thinkphp6使用mysql悲觀鎖解決商品超賣問題的實(shí)現(xiàn)
這篇文章主要介紹了thinkphp6使用mysql悲觀鎖解決商品超賣問題的實(shí)現(xiàn)2021-11-11
php+iframe實(shí)現(xiàn)隱藏?zé)o刷新上傳文件
首先ajax不能上傳文件,這誤導(dǎo)了我有段時(shí)間,今晚睡不著就照著說明做了個(gè)無(wú)刷新上傳文件2012-02-02
如何動(dòng)態(tài)查看及加載PHP擴(kuò)展
這篇文章主要介紹了如何動(dòng)態(tài)查看及加載PHP擴(kuò)展,幫助大家更好的理解和學(xué)習(xí)使用PHP,感興趣的朋友可以了解下2021-04-04
PHP實(shí)現(xiàn)Javascript中的escape及unescape函數(shù)代碼分享
這篇文章主要介紹了PHP實(shí)現(xiàn)Javascript中的escape及unescape函數(shù)代碼分享,本文給出兩個(gè)實(shí)現(xiàn)版本,需要的朋友可以參考下2015-02-02
Laravel + Elasticsearch 實(shí)現(xiàn)中文搜索的方法
這篇文章主要介紹了Laravel + Elasticsearch 實(shí)現(xiàn)中文搜索的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
遍歷echsop的region表形成緩存的程序?qū)嵗a
下面小編就為大家?guī)硪黄闅vechsop的region表形成緩存的程序?qū)嵗a。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11
Yii實(shí)現(xiàn)MySQL多數(shù)據(jù)庫(kù)和讀寫分離實(shí)例分析
這篇文章主要介紹了Yii實(shí)現(xiàn)MySQL多數(shù)據(jù)庫(kù)和讀寫分離的方法,以實(shí)例形式詳細(xì)的分析了Yii數(shù)據(jù)庫(kù)讀寫分離的方法,是開發(fā)大型項(xiàng)目非常實(shí)用的技巧,需要的朋友可以參考下2014-12-12

