Skip to content

Fast Paginate

Forked from hammerstonedev/fast-paginate

關於

這是一個用於 Hyperf 的快速 limit/offset 分頁宏。它可以替代標準的 paginate 方法。

這個包使用了一種類似於“延遲連線”的 SQL 方法來實現這種加速。延遲連線是一種在應用 offsetlimit 之後才訪問請求列的技術。

在我們的例子中,我們實際上並沒有進行連線,而是使用了帶有子查詢的 where in。使用這種技術,我們建立了一個可以透過特定索引進行最佳化的子查詢以達到最大速度,然後使用這些結果來獲取完整的行。

SQL 語句如下所示:

sql
select * from contacts              -- The full data that you want to show your users.
    where contacts.id in (          -- The "deferred join" or subquery, in our case.
        select id from contacts     -- The pagination, accessing as little data as possible - ID only.
        limit 15 offset 150000
    )

執行上述查詢時,您可能會遇到錯誤!例如 This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery. 在這個包中,我們將它們作為兩個獨立的查詢來執行以解決這個問題!

根據您的資料集,效能提升可能會有所不同,但這種方法允許資料庫檢查儘可能少的資料以滿足使用者的需求。

雖然這種方法不太可能比傳統的 offset / limit 效能更差,但也有可能,所以請務必在您的資料上進行測試!

如果您想閱讀關於這個包理論的 3,000 字文章,可以訪問 aaronfrancis.com/2022/efficient-pagination-using-deferred-joins

安裝

shell
composer require friendsofhyperf/fast-paginate

無需執行其他操作,服務提供者將由 Hyperf 自動載入。

使用

在任何您會使用 Model::query()->paginate() 的地方,您都可以使用 Model::query()->fastPaginate()!就是這麼簡單!方法簽名是相同的。

關係也同樣支援:

php
User::first()->posts()->fastPaginate();