」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 限制 Laravel 模型上的急切載重關係

限制 Laravel 模型上的急切載重關係

發佈於2024-11-07
瀏覽:985

Limit Eager Loaded Relationships on Laravel Models

介紹

有時,當您渴望在 Laravel 模型上載入關係時,您可能想要限制返回的相關模型的數量。

例如,在部落格平台上,您可能想要載入系統中的每位作者及其三篇貼文。

在 Laravel 的舊版本中,限制急切加載的關係是一項有點繁瑣的任務。我從來沒有真正找到一種感覺正確的優雅方式來做到這一點。所以我通常會安裝 Jonas Staudenmeir 的 (@staudenmeir) staudenmeir/eloquent-eager-limit 套件來添加此功能。

然而,在今年年初,該包背後的核心功能已合併到 Laravel 框架本身。所以這意味著在 Laravel 11 中,我們可以限制急切加載的關係,而不需要安裝任何額外的套件。

讓我們來看一個例子。

限制 Laravel 中的急切加載關係

假設我們有一個部落格平台,我們希望載入系統中的每位作者及其三篇貼文。

我們可以使用熱切載入查詢中的 limit 方法來實現這一點:

use App\Models\Post;
use App\Models\Author;
use Illuminate\Contracts\Database\Eloquent\Builder;

$authors = Author::query()
    ->with([
        'posts' => fn (Builder $query): Builder => $query->limit(3),
    ])
    ->get();

正如我們在上面的程式碼範例中看到的,我們已經定義了要在 App\Models\Author 模型上預先載入 posts 關係。在急切地載入查詢中,我們使用 limit 方法來指定我們只想載入三個貼文。

底層 SQL 查詢

對於任何有興趣的人,上面的查詢將產生兩個 SQL 查詢。

第一個查詢從資料庫取得作者:

SELECT * FROM `authors`

第二個查詢取得每位作者的三篇文章(假設系統中有 5 位作者):

SELECT *
FROM
    (
        SELECT
            *,
            row_number() OVER (PARTITION BY `posts`.`author_id`) AS `laravel_row`
        FROM `posts`
        WHERE `posts`.`author_id` IN (1, 2, 3, 4, 5)
    ) AS `laravel_table`
WHERE `laravel_row` 



進一步閱讀

如果您喜歡閱讀這篇文章,您可能有興趣查看我的 220 頁電子書“Battle Ready Laravel”,其中更深入地涵蓋了類似的主題。

或者,您可能想查看我的另一本 440 頁電子書“Consuming APIs in Laravel”,它教您如何使用 Laravel 來使用來自其他服務的 API。

如果您有興趣在我每次發布新帖子時獲得更新,請隨時訂閱我的時事通訊。

繼續打造精彩的東西! ?

版本聲明 本文轉載於:https://dev.to/ashallendesign/limit-eager-loaded-relationships-on-laravel-models-4c43?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何在 MySQL 中將行轉置為列:綜合指南
    如何在 MySQL 中將行轉置為列:綜合指南
    在MySQL 中將行轉換為列在MySQL 中將行轉換為列在MySQL 查詢中將行轉換為列需要在應用程式中執行複雜的查詢或手動操作。 GROUP_CONCAT 解雖然 GROUP_CONCAT 可以將行轉換為單列,但它不提供整個結果集所需的轉置。 手動查詢方法對於更複雜的轉置,需要細緻的查詢,從原始行...
    程式設計 發佈於2024-11-07
  • 如何解決iOS後台模式下未收到GCM通知的問題
    如何解決iOS後台模式下未收到GCM通知的問題
    當應用程式在iOS 上處於後台模式時未收到GCM 通知當iOS 在後台收到通知但不處理時,會出現此問題它們在使用者介面中。若要解決此問題,請確保您的應用程式:啟用後台推播通知:檢查您的應用程式是否已要求並取得在背景接收推播通知的權限。 設定徽章應用程式圖示:驗證是否在應用程式的「設定」>「通知」部分...
    程式設計 發佈於2024-11-07
  • 為什麼在 Windows 7 中使用 CLASSPATH 時出現 ClassNotFoundException?
    為什麼在 Windows 7 中使用 CLASSPATH 時出現 ClassNotFoundException?
    儘管使用CLASSPATH 環境變數仍解決java.lang.ClassNotFoundException在Windows 7 中嘗試使用Java 連線至MySQL 資料庫時,設定CLASSPATH 環境變數以包含JDBC 驅動程式jar 檔案的路徑似乎無法解決java.lang.ClassNotF...
    程式設計 發佈於2024-11-07
  • 開發人員需要了解免費外匯 API
    開發人員需要了解免費外匯 API
    如果您是一名开发人员,您一定正在寻找可以帮助您更轻松地工作的工具,对吗?免费的外汇 API 就是其中之一!它使您无需支付任何费用即可获取外汇汇率。但是,许多开发人员对这些 API 不太了解。因此,本文旨在解释什么是免费外汇 API、它为何有用以及如何为您的项目选择一个 API。 什么是免费外汇 A...
    程式設計 發佈於2024-11-07
  • 如何使用 JavaScript 將字串中每個單字的首字母大寫?
    如何使用 JavaScript 將字串中每個單字的首字母大寫?
    使用JavaScript 將字串中每個單字的首字母大寫在JavaScript 中,將字串中每個單字的首字母大寫可以透過多種方法來實現。一種常見的方法是使用將給定字串轉換為標題大小寫的函數。 讓我們探索一個示範此技術的程式碼範例:function titleCase(str) { var spli...
    程式設計 發佈於2024-11-07
  • 我們能否在 JavaScript 中實現超越「setTimeout()」的可靠計時器精度?
    我們能否在 JavaScript 中實現超越「setTimeout()」的可靠計時器精度?
    在Javascript 中實現超越setTimeout() 的計時器精度Javascript 的setTimeout() 方法在精度方面經常達不到要求,表現出不可預測的延遲,可能會影響UI 操作。因此,開發人員可能想知道是否有其他方法可以提供更可靠的計時功能。 使用 setTimeout() 獲得精...
    程式設計 發佈於2024-11-07
  • 使用 Amazon Q Transformation 將 Java 頌歌轉換為 Java
    使用 Amazon Q Transformation 將 Java 頌歌轉換為 Java
    近年来,Java 取得了显着的进步,每个新版本都引入了强大的功能和优化。如果您仍在 Java 8 上运行,您就会错过性能、语法和安全性方面的重大改进。从 Java 8 升级到 Java 17 似乎令人畏惧,但 Amazon Q 的转换功能通过自动化一些较繁琐的步骤使升级变得更加容易。在这篇文章中,我...
    程式設計 發佈於2024-11-07
  • 使用 React 建立食譜查找器網站
    使用 React 建立食譜查找器網站
    Introduction In this blog, we'll be building a Recipe Finder Website using React. This app allows users to search for their favorite recipes,...
    程式設計 發佈於2024-11-07
  • Turborepo 與 Nx:哪種 Monorepo 工具適合您?
    Turborepo 與 Nx:哪種 Monorepo 工具適合您?
    随着现代开发变得越来越复杂,monorepos变得越来越流行。它们允许将多个项目或包存储在单个存储库中,从而简化依赖关系管理并促进更好的协作。用于管理 monorepos 的两个顶级工具是 Turborepo 和 Nx。 这两种工具都旨在提高处理单一存储库的效率和可扩展性,但它们具有独特的优势。在本...
    程式設計 發佈於2024-11-07
  • Java 陣列簡介
    Java 陣列簡介
    编程通常涉及管理和操作大量数据,对此高效且有效的数据结构至关重要。数组是计算机科学中的基本数据结构,提供了一种存储固定大小的相同类型元素序列的方法。在本博客中,我们将深入了解 Java 中的数组:了解它们是什么、它们的语法、如何对它们进行操作以及它们的内存管理。 为什么我们需要数组?...
    程式設計 發佈於2024-11-07
  • 解決 CORS 問題的方法
    解決 CORS 問題的方法
    要解决 CORS 问题,您需要在 Web 服务器(如 Apache 或 Nginx)、后端(如 Django、Go 或 Node.js)中添加适当的标头,或在前端框架(如 React 或 Next.js)中。以下是每个平台的步骤: 1. 网络服务器 阿帕奇 您可以在 ...
    程式設計 發佈於2024-11-07
  • 記憶體對齊如何影響 C 結構的大小?
    記憶體對齊如何影響 C 結構的大小?
    C 結構中的記憶體對齊使用 C 結構時,理解記憶體對齊至關重要。記憶體對齊是指將資料在記憶體中放置在特定的邊界處。在 32 位元機器上,記憶體通常按 4 位元組邊界對齊。 結構的記憶體對齊考慮以下結構:typedef struct { unsigned short v1; unsig...
    程式設計 發佈於2024-11-07
  • 受頂級旅遊景點啟發建構創新項目:令人難忘的旅遊體驗開發人員指南
    受頂級旅遊景點啟發建構創新項目:令人難忘的旅遊體驗開發人員指南
    作為開發商,我們經常從周圍的世界中汲取靈感——還有什麼比令人難以置信的旅遊景點更好的來源呢?無論您是在開發旅行應用程式、沉浸式體驗還是基於位置的服務,了解目的地的脫穎而出都是關鍵。看看這份關於阿爾巴尼亞最佳旅遊景點的終極指南,為您的下一個創意項目提供動力,並了解這些地標如何在現實世界和數位世界中塑造...
    程式設計 發佈於2024-11-07
  • 如何使用 std::locale 在 C++ 中使用逗號格式化數字?
    如何使用 std::locale 在 C++ 中使用逗號格式化數字?
    在C 中用逗號格式化數字在C 中,std::locale 類別提供了一種依賴於區域設定的方式用逗號格式化數字.std::locale 與std::stringstream要將數字格式化為帶逗號的字串,可以將std::locale 與std::stringstream 一起使用如下:#include ...
    程式設計 發佈於2024-11-07
  • 如何避免在 Python 中列印素數序列中的奇數?
    如何避免在 Python 中列印素數序列中的奇數?
    如何在 Python 中列印素數序列許多程式設計師都在努力創建一個在 Python 中準確列印素數的函數。一個常見的問題是列印奇數列表。要解決這個問題,必須徹底了解素數屬性並修改程式碼。 質數只能被 1 和它們本身整除。因此,改進的程式碼檢查從 2 到數字的平方根(如果數字較小,則為數字本身)範圍內...
    程式設計 發佈於2024-11-07

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3