佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > laravel中Join語法以及使用Join多個條件

laravel中Join語法以及使用Join多個條件

熱門標(biāo)簽:阿里云 電子圍欄 銀行業(yè)務(wù) 服務(wù)器配置 團(tuán)購網(wǎng)站 科大訊飛語音識別系統(tǒng) Linux服務(wù)器 Mysql連接數(shù)設(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)于laravel中Join語法以及使用Join多個條件的文章就介紹到這了,更多相關(guān)laravel中Join語法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Laravel 重寫日志,讓日志更優(yōu)雅
  • laravel使用組件實(shí)現(xiàn)微信網(wǎng)頁授權(quán)登入
  • Laravel統(tǒng)一封裝接口返回狀態(tài)實(shí)例講解
  • laravel join關(guān)聯(lián)查詢代碼實(shí)例
  • laravel框架的緩存操作代碼實(shí)例
  • laravel日志優(yōu)化實(shí)例講解
  • laravel下trait的使用代碼實(shí)例詳解
  • 清除laravel緩存命令代碼實(shí)例
  • 如何用Laravel包含你自己的幫助函數(shù)

標(biāo)簽:蚌埠 衢州 大理 廣元 江蘇 萍鄉(xiāng) 棗莊 衡水

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《laravel中Join語法以及使用Join多個條件》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    乌兰县| 滦南县| 木兰县| 新安县| 城市| 万州区| 西贡区| 萍乡市| 白朗县| 赫章县| 自贡市| 习水县| 会理县| 香港| 阜平县| 阜新市| 四会市| 灵寿县| 肇源县| 安吉县| 本溪市| 北川| 永丰县| 云梦县| 桦川县| 阿尔山市| 沅江市| 碌曲县| 云林县| 牟定县| 康马县| 洮南市| 航空| 漳浦县| 富民县| 大名县| 贵定县| 府谷县| 巴塘县| 青龙| 马公市|