這篇文章主要為大家介紹了關於laravel技巧之查詢建構器Query Builder疊加鍊式呼叫的相關資料,文中透過範例程式碼介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友下面來一起看看吧。
查詢建構器簡介
Laravel查詢建構器(query builder)提供方便、流暢的接口,用來建立及執行資料庫查找語法
使用PDO參數綁定,以保護應用程式免於SQL注入。因此傳入的參數不需額外轉義特殊字元
基本上可以滿足所有的資料庫操作,而且在所有支援的資料庫系統上都可以執行
引言
今天要跟大家介紹一下laravel查詢建構器的一個小技巧,在官方文件範例中沒有詳細提到,也不是啥高階技巧,可能很多人在用了,不知道的同學可以看看。
在業務程式碼中經常會根據不同條件來查詢,舉個簡單例子,我們現在要查詢用戶列表,按時間倒序排列,可能會有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(),寫了四遍,如果產品說今天我們要正序排列,那你得改四個地方。雖然用編輯器改一下也很快,不過要知道這只是個最簡單的例子。
看了下文檔有個when方法進行條件判斷,一堆閉包也不是很理想。我堅信肯定有更優雅的寫法,於是上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();
#用變數儲存查詢建構器實例,然後在其上疊加約束條件,最後get集合。公共部分放在首尾,結構清晰,是不是高下立判啊?
而且我們還可以把$query當成參數傳入方法或函數中,將公共邏輯封裝在一起,方便多處呼叫:
function foo($query) { $query->with(['girl', 'gay']) ->latest() ->get(); } $query = User::query(); $users = foo($query);
這種寫法有一個注意事項,一旦你在$query上呼叫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 方法針對查詢表回傳一個查詢建構器實例,讓你在查詢時鍊式呼叫更多約束,並使用get 方法取得最終結果
題外話
以前聽一些老前輩說他們不要只會百度的程式設計師,當時感覺真裝嗶,不都是搜尋引擎,因為我那時不用google。現在我也不願意跟只會百度的共事了,百度只是個廣告搜尋嘛,搜出來的都是些啥玩意。
google、stackoverflow真是個好東西,很多歪果仁知識豐富,解答專業,從電腦歷史到作業系統、資料庫、各種程式語言,幫我de了很多bug。在segmentfault這麼打廣告是不是不好,溜了!
總結
Reference:
How to create multiple where clause query using Laravel Eloquent? - stackoverflow
Model::query - laravelAPI
您可能有興趣的文章:
#
以上是laravel技巧之查詢建構器Query Builder疊加鍊式呼叫方法的講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

負載均衡會影響會話管理,但可以通過會話複製、會話粘性和集中式會話存儲解決。 1.會話複製在服務器間複製會話數據。 2.會話粘性將用戶請求定向到同一服務器。 3.集中式會話存儲使用獨立服務器如Redis存儲會話數據,確保數據共享。

Sessionlockingisatechniqueusedtoensureauser'ssessionremainsexclusivetooneuseratatime.Itiscrucialforpreventingdatacorruptionandsecuritybreachesinmulti-userapplications.Sessionlockingisimplementedusingserver-sidelockingmechanisms,suchasReentrantLockinJ

PHP會話的替代方案包括Cookies、Token-basedAuthentication、Database-basedSessions和Redis/Memcached。 1.Cookies通過在客戶端存儲數據來管理會話,簡單但安全性低。 2.Token-basedAuthentication使用令牌驗證用戶,安全性高但需額外邏輯。 3.Database-basedSessions將數據存儲在數據庫中,擴展性好但可能影響性能。 4.Redis/Memcached使用分佈式緩存提高性能和擴展性,但需額外配

Sessionhijacking是指攻擊者通過獲取用戶的sessionID來冒充用戶。防範方法包括:1)使用HTTPS加密通信;2)驗證sessionID的來源;3)使用安全的sessionID生成算法;4)定期更新sessionID。

本文比較了PHP和ASP.NET,重點是它們對大規模Web應用程序,性能差異和安全功能的適用性。兩者對於大型項目都是可行的,但是PHP是開源和無關的,而ASP.NET,


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

禪工作室 13.0.1
強大的PHP整合開發環境