這篇文章將為大家詳細(xì)講解有關(guān)laravel中如何使用Join語法,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

在laravel中我們常常會使用join,leftjion和rightjoin進(jìn)行連表查詢,非常的方便,但是我今天遇到一個問題,就是鏈表查詢需要on多個條件,即我要訂單的id和發(fā)貨人都一樣,默認(rèn)的join只支持單個查詢,所以我下面總結(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]);二、使用高級的Join語法(推薦使用)
我們只需要所以如下代碼即可完成我們的Join多個條件
DB::table('users')
->join('contacts', function ($join) {
$join->on('users.id', '=','contacts.user_id')->on('users.usename', '=','contacts.usename');
})
->get();如果你想要了解更多,我們可以看一下文檔中的描述:
讓我們以傳入一個閉包當(dāng)作 join 方法的第二參數(shù)來作為開始。此閉包會接收 JoinClause 對象,讓你可以在 join 子句上指定約束:
DB::table('users')
->join('contacts', function ($join) {
$join->on('users.id', '=','contacts.user_id')->orOn(...);
})
->get();若你想要在連接中使用「where」風(fēng)格的子句,則可以在連接中使用 where 和 orWhere 方法。這些方法會比較字段和一個值,來代替兩個字段的比較:
DB::table('users')
->join('contacts', function ($join) {
$join->on('users.id', '=', 'contacts.user_id')
->where('contacts.user_id', '>', 5);
})
->get();關(guān)于“l(fā)aravel中如何使用Join語法”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
當(dāng)前名稱:laravel中如何使用Join語法-創(chuàng)新互聯(lián)
本文鏈接:http://chinadenli.net/article48/edphp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)、服務(wù)器托管、網(wǎng)站設(shè)計、網(wǎng)站導(dǎo)航、自適應(yīng)網(wǎng)站、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容