首頁 > 資料庫 > mysql教程 > 如何在不使用分析函數的情況下有效率地選擇 MySQL 中每個類別的前幾行?

如何在不使用分析函數的情況下有效率地選擇 MySQL 中每個類別的前幾行?

DDD
發布: 2024-10-28 19:05:29
原創
212 人瀏覽過

How to Efficiently Select Top Rows per Category in MySQL Without Analytic Functions?

在MySQL 中選擇每個類別的前幾行

要從表中的每個類別中檢索有限數量的行,您可以使用分析函數。然而,MySQL 並不會直接提供這些功能。不過,可以使用變數來模擬它們。

模擬分析函數

以下MySQL 查詢模擬分析函數的功能,以選擇每個類別的前3 行:

<code class="mysql">SELECT x.*
FROM (
    SELECT t.*,
    CASE 
        WHEN @category != t.category THEN @rownum := 1 
        ELSE @rownum := @rownum + 1 
    END AS rank,
    @category := t.category AS var_category
    FROM TBL_ARTIKUJT t
    JOIN (SELECT @rownum := NULL, @category := '') r
    ORDER BY t.category
) x
WHERE x.rank <= 3</code>
登入後複製

說明

  • 子查詢從TBL_ARTIKUJT 表中選擇所有行,並初始化兩個會話變數@rownum 和@category,以追蹤目前排名和類別。
  • 分配給每行的排名表示其在其類別中的位置。當遇到新類別時,排名重設為 1。
  • var_category 用於儲存每行的類別。
  • 外部 SELECT 語句篩選子查詢,僅選擇具有排名的行小於或等於 3。

此方法可讓您在不依賴 MySQL 不支援的分析函數的情況下實現所需的功能。

以上是如何在不使用分析函數的情況下有效率地選擇 MySQL 中每個類別的前幾行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板