laravel中Join語法以及使用Join多個(gè)條件
在laravel中我們常常會使用join,leftjion和rightjoin進(jìn)行連表查詢,非常的方便,但是我今天遇到一個(gè)問題,就是鏈表查詢需要on多個(gè)條件,即我要訂單的id和發(fā)貨人都一樣,默認(rèn)的join只支持單個(gè)查詢,所以我下面總結(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多個(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ù)來作為開始。此閉包會接收 JoinClause 對象,讓你可以在 join 子句上指定約束:
DB::table('users')
->join('contacts', function ($join) {
$join->on('users.id', '=','contacts.user_id')->orOn(...);
})
->get();
若你想要在連接中使用「where」風(fēng)格的子句,則可以在連接中使用 where 和 orWhere 方法。這些方法會比較字段和一個(gè)值,來代替兩個(gè)字段的比較:
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多個(gè)條件的文章就介紹到這了,更多相關(guān)laravel中Join語法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Yii框架批量插入數(shù)據(jù)擴(kuò)展類的簡單實(shí)現(xiàn)方法
這篇文章主要介紹了Yii框架批量插入數(shù)據(jù)擴(kuò)展類的簡單實(shí)現(xiàn)方法,涉及Yii擴(kuò)展類及數(shù)據(jù)庫相關(guān)操作技巧,需要的朋友可以參考下2017-05-05
PHP 二維關(guān)聯(lián)數(shù)組根據(jù)其中一個(gè)字段排序(推薦)
這篇文章主要介紹了PHP 二維關(guān)聯(lián)數(shù)組根據(jù)其中一個(gè)字段排序的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-04-04
PHP getallheaders無法獲取自定義頭(headers)的問題
這篇文章主要介紹了PHP getallheaders無法獲取自定義頭(headers)的問題的相關(guān)資料,需要的朋友可以參考下2016-03-03
微信公眾平臺實(shí)現(xiàn)獲取用戶OpenID的方法
這篇文章主要介紹了微信公眾平臺實(shí)現(xiàn)獲取用戶OpenID的方法,需要開發(fā)人員經(jīng)過微信授權(quán)后獲取高級接口才能使用此功能,用戶OpenID對于微信公眾平臺建設(shè)有著非常廣泛的用途,需要的朋友可以參考下2015-04-04
php實(shí)現(xiàn)cc攻擊防御和防止快速刷新頁面示例
這篇文章主要介紹了php實(shí)現(xiàn)cc攻擊防御的方法和防止快速刷新頁面示例,需要的朋友可以參考下2014-02-02
php中創(chuàng)建和調(diào)用webservice接口示例
這篇文章主要介紹了php中創(chuàng)建和調(diào)用webservice接口示例,包括webservice基本知識、webservice服務(wù)端例子、webservice客戶端例子,需要的朋友可以參考下2014-07-07

