溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

laravel中如何使用Join語(yǔ)法

發(fā)布時(shí)間:2021-08-09 10:05:26 來(lái)源:億速云 閱讀:107 作者:小新 欄目:開(kāi)發(fā)技術(shù)

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

在laravel中我們常常會(huì)使用join,leftjion和rightjoin進(jìn)行連表查詢,非常的方便,但是我今天遇到一個(gè)問(wèn)題,就是鏈表查詢需要on多個(gè)條件,即我要訂單的id和發(fā)貨人都一樣,默認(rèn)的join只支持單個(gè)查詢,所以我下面總結(jié)兩種方法:

一、使用原是表達(dá)式(不推薦)

原生SQL中我們可以通過(guò)如下方法進(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ù)來(lái)作為開(kāi)始。此閉包會(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è)值,來(lái)代替兩個(gè)字段的比較:

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語(yǔ)法”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI