在MySQL 中選擇每個類別的前幾行
要從表中的每個類別中檢索有限數量的行,您可以使用分析函數。然而,MySQL 並不會直接提供這些功能。不過,可以使用變數來模擬它們。
模擬分析函數
以下MySQL 查詢模擬分析函數的功能,以選擇每個類別的前3 行:
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 解釋
- 子查詢從TBL_ARTIKUJT 表中選擇所有行並初始化兩個會話變數@rownum 和@category,追蹤當前排名和類別。
- 分配給每行的排名指示其在其類別中的位置。當遇到新類別時,rank 重設為 1。
- var_category 用於儲存每行的類別。
- 外部 SELECT 語句篩選子查詢,僅選擇具有排名的行小於或等於3。
此方法可讓您在不依賴解析函數的情況下實作所需的功能,而解析函數不支援MySQL。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3