濮阳杆衣贸易有限公司

主頁 > 知識庫 > laravel高級的Join語法詳解以及使用Join多個條件

laravel高級的Join語法詳解以及使用Join多個條件

熱門標(biāo)簽:格陵蘭島地圖標(biāo)注 熱線電話機器人 太原極信防封電銷卡 電銷招聘機器人 福泉電話機器人 南寧crm外呼系統(tǒng)平臺 天津營銷電話機器人加盟代理 地圖標(biāo)注入哪個科目 事業(yè)單位如何百度地圖標(biāo)注

在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();

以上這篇laravel高級的Join語法詳解以及使用Join多個條件就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • laravel join關(guān)聯(lián)查詢代碼實例
  • 關(guān)于laravel 子查詢 & join的使用
  • Laravel 連接(Join)示例
  • 解決在laravel中l(wèi)eftjoin帶條件查詢沒有返回右表為NULL的問題
  • laravel中Join語法以及使用Join多個條件

標(biāo)簽:寶雞 金華 佳木斯 香港 郴州 阿克蘇 自貢 通化

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《laravel高級的Join語法詳解以及使用Join多個條件》,本文關(guān)鍵詞  laravel,高級的,Join,語法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《laravel高級的Join語法詳解以及使用Join多個條件》相關(guān)的同類信息!
  • 本頁收集關(guān)于laravel高級的Join語法詳解以及使用Join多個條件的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    江都市| 岳西县| 沽源县| 江口县| 泸州市| 四川省| 荣昌县| 荣成市| 乌拉特前旗| 黄浦区| 岳池县| 定陶县| 金平| 揭西县| 双辽市| 屏南县| 屯昌县| 清苑县| 宜都市| 彝良县| 万荣县| 全南县| 兖州市| 新乐市| 汉阴县| 克拉玛依市| 台东市| 河西区| 定西市| 从化市| 鹰潭市| 阿拉善左旗| 牙克石市| 梅河口市| 来宾市| 三门峡市| 长岭县| 乌兰察布市| 会泽县| 南开区| 东台市|