在laravel中我們常常會使用join,leftjion和rightjoin進行連表查詢,非常的方便,但是我今天遇到一個問題,就是鏈表查詢需要on多個條件,即我要訂單的id和發貨人都一樣,默認的join只支持單個查詢,所以我下面總結兩種方法:
一、使用原是表達式(不推薦)
原生SQL中我們可以通過如下方法進行
1
|
select * from `orders` left join `users` on `orders`.`usename`=`users`.`usename` and `orders`.`platform`=`users`.`platform` where `orders`.`order_status` = 2 |
那么結合laravel,我們可以所以
1
|
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多個條件
1
2
3
4
5
|
DB:: table ( 'users' ) -> join ( 'contacts' , function ($ join ) { $ join -> on ( 'users.id' , '=' , 'contacts.user_id' )-> on ( 'users.usename' , '=' , 'contacts.usename' ); }) ->get(); |
如果你想要了解更多,我們可以看一下文檔中的描述:
讓我們以傳入一個閉包當作 join 方法的第二參數來作為開始。此閉包會接收 JoinClause 對象,讓你可以在 join 子句上指定約束:
1
2
3
4
5
|
DB:: table ( 'users' ) -> join ( 'contacts' , function ($ join ) { $ join -> on ( 'users.id' , '=' , 'contacts.user_id' )->orOn(...); }) ->get(); |
若你想要在連接中使用「where」風格的子句,則可以在連接中使用 where 和 orWhere 方法。這些方法會比較字段和一個值,來代替兩個字段的比較:
1
2
3
4
5
6
|
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語法內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/sunjinyan_1/article/details/82349877