1. 程式人生 > 程式設計 >laravel中Join語法以及使用Join多個條件

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

在laravel中我們常常會使用join,leftjion和rightjoin進行連表查詢,非常的方便,但是我今天遇到一個問題,就是連結串列查詢需要on多個條件,即我要訂單的id和發貨人都一樣,預設的join只支援單個查詢,所以我下面總結兩種方法:

一、使用原是表示式(不推薦)

原生SQL中我們可以通過如下方法進行

select * from `orders` left join `users` on `orders`.`usename`=`users`.`usename` and `orders`.`platform`=`users`.`platform` where `orders`.`order_status` = 2

那麼結合laravel,我們可以所以

DB::select('select * from `orders` left join `users` http://www.cppcns.comon `orders`.`usename`=`users`.`usename` and `orders`.`platform`=`users`.`platform` where `orders`.`order_status` = :idhttp://www.cppcns.com',['id' => 1]);

二、使用高階的Join語法(推薦使用)

我們只需要所以如下程式碼即可完成我們的Join多個條件

DB::table('users')
 ->join('contacts',function ($join) {
  $join->on('users.id','=','contacts.user_id')->on('users.usename','contacts.usename');
  })
 ->get();

如果你想要了解更多,我們可以看一下文件中的描述:

讓我們以傳入一個閉包當作 join 方法的第二引數來作為開始。此閉包會接收 JoinClause 物件,讓你可以在 join 子句上指定約束:

DB::table('users')
 ->join('contacts'http://www.cppcns.com,functiyiEvPzghbon ($join) {
  $join->on('users.id','contacts.user_id')->orOn(...);
  })
 ->get();

若你想要在連線中使用「where」風格的子句,則可以在連線中使用 where 和 orWhere 方法。這些方法會比較欄位和一個值,來代http://www.cppcns.com

替兩個欄位的比較:

DB::table('users')
  ->join('contacts',function ($join) {
   $join->on('users.id','contacts.user_id')
     ->where('contacts.user_id','>',5);
  })
  ->get();

到此這篇關於laravel中Join語法以及使用Join多個條件的文章就介紹到這了,更多相關laravel中Join語法內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!