laravel中firstOrNew, firstOrCreate, firstOr 和 updateOrCreate 方法
下面由Laravel開發入門教學專欄為大家介紹使用laravel中firstOrNew, firstOrCreate, firstOr 和 updateOrCreate 方法,希望對需要的朋友有幫助!
如果您曾經使用過 Laravel ,那麼您可能知道建立 Eloquent 模型的標準方法,例如 make(),create(),update 和 save()。 Laravel 也提供了一些大家沒有註意到的其他方法,這些方法對於建立和更新模型也非常有用。因此,在本文中,我想介紹一些其他方法,並說明它們可能會有用:
firstOrNew
firstOrNew 方法找到第一個滿足某些限制的模型,沒有滿足約束條件的資料時new 一個新的模型。
您可以採用以下程式碼:
$user = User::where('email', request('email'))->first(); if ($user === null) { $user = new User(['email' => request('email')]); } $user->name = request('name'); $user->save()
並將其改寫成:
$user = User::firstOrNew(['email' => request('email')]); $user->name = request('name'); $user->save()
如果找不到已有的模型,您也可以透過第二個參數傳遞一個附加屬性陣列:
$user = User::firstOrNew( ['email' => request('email')], ['name' => request('name')] ); $user->save();
firstOrCreate
#firstOrCreate 方法跟firstOrNew 方法很相似。它會嘗試根據你傳遞的第一個參數去尋找匹配的模型,如果沒找到,會自動用第二個參數傳遞的值創建並且保存一個新的模型:
$user = User::firstOrCreate( ['email' => request('email')], ['name' => request('name')] ); // No call to $user->save() needed
firstOr
我最近摸魚的時候發現了firstOr 這個方法。 firstOr 方法會檢索第一個數據,如果沒有找到匹配的數據,就會執行傳入的回調。如果您在建立使用者時需要執行額外的步驟,或者想要執行除建立新使用者以外的其他操作,這將非常有用:
$user = User::where('email', request('email'))->firstOr(function () { $account = Account::create([ //... ]); return User::create([ 'account_id' => $account->id, 'email' => request('email'), ]); });
updateOrCreate
updateOrCreate 方法試圖找出一個與第一個參數傳遞的限制條件相符的模型。如果找到匹配的模型,它將使用第二個參數傳遞的屬性來更新模型。如果找不到匹配的模型,則將建立一個新模型,同時將第一個參數和第二個參數傳入。
您可以重構這段程式碼:
$user = User::where('email', request('email'))->first(); if ($user !== null) { $user->update(['name' => request('name')]); } else { $user = User::create([ 'email' => request('email'), 'name' => request('name'), ]); } // Do other things with the User
使用updateOrCreate 方法:
$user = User::updateOrCreate( ['email' => request('email')], ['name' => request('name')] ); // Do other things with the User
結論
##總的來說,我認為這些方法可以在某些情況下幫助您簡化程式碼!您是否知道其他一些有用又不為人所知的小技巧, 有的話記得告訴我。我喜歡學習這些讓 Laravel 變得如此出色的小細節。 更多laravel框架技術文章,請造訪以上是laravel中firstOrNew, firstOrCreate, firstOr 和 updateOrCreate 方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

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

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Laravel郵件發送失敗時的退信代碼獲取方法在使用Laravel開發應用時,經常會遇到需要發送驗證碼的情況。而在實�...

LaravelEloquent模型檢索:輕鬆獲取數據庫數據EloquentORM提供了簡潔易懂的方式來操作數據庫。本文將詳細介紹各種Eloquent模型檢索技巧,助您高效地從數據庫中獲取數據。 1.獲取所有記錄使用all()方法可以獲取數據庫表中的所有記錄:useApp\Models\Post;$posts=Post::all();這將返回一個集合(Collection)。您可以使用foreach循環或其他集合方法訪問數據:foreach($postsas$post){echo$post->

在Laravel6項目中如何檢查Redis連接的有效性是一個常見的問題,特別是在項目依賴於Redis進行業務處理時。以下是...

Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。

利用地理空間技術高效處理700萬條記錄並創建交互式地圖本文探討如何使用Laravel和MySQL高效處理超過700萬條記錄,並將其轉換為可交互的地圖可視化。初始挑戰項目需求:利用MySQL數據庫中700萬條記錄,提取有價值的見解。許多人首先考慮編程語言,卻忽略了數據庫本身:它能否滿足需求?是否需要數據遷移或結構調整? MySQL能否承受如此大的數據負載?初步分析:需要確定關鍵過濾器和屬性。經過分析,發現僅少數屬性與解決方案相關。我們驗證了過濾器的可行性,並設置了一些限制來優化搜索。地圖搜索基於城

Laravel是如何在後端邏輯中發揮作用的?它通過路由系統、EloquentORM、認證與授權、事件與監聽器以及性能優化來簡化和增強後端開發。 1.路由系統允許定義URL結構和請求處理邏輯。 2.EloquentORM簡化數據庫交互。 3.認證與授權系統便於用戶管理。 4.事件與監聽器實現松耦合代碼結構。 5.性能優化通過緩存和隊列提高應用效率。

在使用CraftCMS開發網站時,常常會遇到資源文件緩存的問題,特別是當你頻繁更新CSS和JavaScript文件時,舊版本的文件可能仍然被瀏覽器緩存,導致用戶無法及時看到最新的更改。這個問題不僅影響用戶體驗,還會增加開發和調試的難度。最近,我在項目中遇到了類似的困擾,經過一番探索,我找到了wiejeben/craft-laravel-mix這個插件,它完美地解決了我的緩存問題。

Laravel 提供了一個全面的 Auth 框架,用於實現用戶登錄功能,包括:定義用戶模型(Eloquent 模型)創建登錄表單(Blade 模板引擎)編寫登錄控制器(繼承 Auth\LoginController)驗證登錄請求(Auth::attempt)登錄成功後重定向(redirect)考慮安全因素:哈希密碼、防 CSRF 保護、速率限制和安全標頭。此外,Auth 框架還提供重置密碼、註冊和驗證電子郵件等功能。詳情請參閱 Laravel 文檔:https://laravel.com/doc
