您的位置:首页 >MySQL 5.7 按类别取前2条记录方法
发布于2026-04-18 阅读(0)
扫一扫,手机访问

本文介绍在不支持窗口函数的 MySQL 5.7 环境下,高效实现“按 category 分组并各取前 2 行”的实用方案,包含兼容性 SQL 写法、原理说明及关键注意事项。
本文介绍在不支持窗口函数的 MySQL 5.7 环境下,高效实现“按 category 分组并各取前 2 行”的实用方案,包含兼容性 SQL 写法、原理说明及关键注意事项。
在 MySQL 5.7 及更早版本中,ROW_NUMBER() OVER (PARTITION BY ...) 等窗口函数不可用,因此无法直接使用现代 SQL 中简洁的分组排序限行语法。但通过巧妙利用 GROUP_CONCAT() 与 FIND_IN_SET() 的组合,我们仍可实现「每个 category 取前 N 条记录」的目标——尤其适用于每类固定取前 2 行这类常见需求。
以下为完整、可运行的解决方案(假设表名为 food):
SELECT food.*
FROM food
JOIN (
SELECT
category,
GROUP_CONCAT(id ORDER BY id) AS ids -- 按 id 升序拼接,确保“前2条”逻辑可控
FROM food
GROUP BY category
) AS category_ids
ON food.category = category_ids.category
WHERE FIND_IN_SET(food.id, category_ids.ids) BETWEEN 1 AND 2;✅ 关键说明:
⚠️ 注意事项:
? 进阶提示:
若需动态控制每类取 N 行(如 N=3、N=5),可将 BETWEEN 1 AND 2 改为变量或参数化条件,配合存储过程进一步封装复用。
该方案已在 MySQL 5.7 生产环境稳定验证,兼顾兼容性、可读性与实用性,是旧版本分组 Top-N 查询的经典替代解法。
下一篇:Go 中正确计算二次方程根的方法
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9