您好,登錄后才能下訂單哦!
小編給大家分享一下laravel技巧之查詢構(gòu)造器Query Builder疊加鏈式調(diào)用的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
查詢構(gòu)造器簡介
Laravel查詢構(gòu)造器(query builder)提供方便、流暢的接口,用來建立及執(zhí)行數(shù)據(jù)庫查找語法
使用PDO參數(shù)綁定,以保護應用程序免于SQL注入。因此傳入的參數(shù)不需額外轉(zhuǎn)義特殊字符
基本可以滿足所有的數(shù)據(jù)庫操作,而且在所有支持的數(shù)據(jù)庫系統(tǒng)上都可以執(zhí)行
引言
今天給大家介紹一下laravel查詢構(gòu)造器的一個小技巧,在官方文檔示例中沒有詳細提到,也不是啥高端技巧,可能很多人在用了,不知道的同學可以看看。
在業(yè)務代碼中經(jīng)常會根據(jù)不同條件來查詢,舉個簡單例子,我們現(xiàn)在要查詢用戶列表,按時間倒序排列,可能會有status和type作為限定條件。
一開始我是這樣寫的
if($status && $type) { $users = User::where('status', $status)->where('type', $type)->latest()->get(); } else if ($status) { $users = User::where('status', $status)->latest()->get(); } else if ($type) { $users = User::where('status', $type)->latest()->get(); } else { $users = User::latest()->get(); }
這個代碼真的很丑陋,很多公共代碼,比如->latest()->get(),寫了四遍,如果產(chǎn)品說今天我們要正序排列,那你得改四個地方。雖然借助編輯器改一下也很快,不過要知道這只是個最簡單的例子。
看了下文檔有個when方法進行條件判斷,一堆閉包也不是很理想。我堅信肯定有更優(yōu)雅的寫法,于是上stackoverflow搜了一波,果然萬能的歪果仁給了我答案。
改進后的寫法:
$query = User::query(); // 如果用DB: $query = DB::table('user'); if ($status) { $query->where('status', $status); } if ($type) { $query->where('type', $type); } $users = $query->latest()->get();
用變量保存查詢構(gòu)造器實例,然后在其上疊加約束條件,最后get集合。公共部分放在首尾,結(jié)構(gòu)清晰,是不是高下立判?。?/p>
而且我們還可以把$query當成參數(shù)傳入方法或函數(shù)中,將公共邏輯封裝在一起,方便多處調(diào)用:
function foo($query) { $query->with(['girl', 'gay']) ->latest() ->get(); } $query = User::query(); $users = foo($query);
這種寫法有一個注意事項,一旦你在$query上調(diào)用where等約束方法,就會改變此query,有時候我們需要提前clone一個query。
舉例說明,比如我們同時要拿到type為1和2的users
$query_1 = User::query(); $query_2 = clone $query_1; $users_1 = $query_1->where('type', 1)->latest()->get(); $users_2 = $query_2->where('type', 2)->latest()->get(); // 錯誤 $users_2 = $query_1->where('type', 1)->latest()->get(); // 這樣寫得到得是type = 1 and $type = 2
laravel的文檔里雖然沒有寫這種示例,但是提了一下:
你可以使用 DB facade 的 table 方法開始查詢。這個 table 方法針對查詢表返回一個查詢構(gòu)造器實例,允許你在查詢時鏈式調(diào)用更多約束,并使用 get 方法獲取最終結(jié)果
題外話
以前聽一些老前輩說他們不要只會百度的程序員,當時感覺真裝嗶,不都是搜索引擎,因為我那時不用google?,F(xiàn)在我也不愿意和只會百度的共事了,百度只是個廣告搜索嘛,搜出來的都是些啥玩意。
google、stackoverflow真是個好東西,很多歪果仁知識豐富,解答專業(yè),從計算機歷史到操作系統(tǒng)、數(shù)據(jù)庫、各種編程語言,幫我de了好多bug。在segmentfault這么打廣告是不是不好,溜了!
以上是“l(fā)aravel技巧之查詢構(gòu)造器Query Builder疊加鏈式調(diào)用的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。