分组后查找每组的前N条记录语句_MySQL
程序员文章站
2022-06-13 15:39:53
...
bitsCN.com
分组后查找每组的前N条记录语句 Java代码 考你一条sql语句 如有表 student id name age class 1 张1 15 1 2 张2 15 1 3 张3 15 1 4 张4 15 2 5 张5 15 2 6 张6 15 2 7 张7 15 3 8 张8 15 3 9 张9 15 3 10 张10 15 5 11 张11 15 5
现在想得到每个班级的前2名学生资料 根据题意是,按class分组,然后取id靠前的两名,相信大多数人都能想到基本组合: SELECT a.* FROM student a ORDER BY a.class, a.id; 另加:Limit 0,2来配合。 (注:MYSQL 中没有top n的写法,取代的是LIMIT。) Limit 0,n只能取到最前的n位,但如何能取到每个班的前两位呢,就无从下手了。 下面我来具体分析一下这题的解法: 1、获取每个class的前两位: SELECT a.* FROM student a WHERE ( SELECT COUNT(*) FROM student WHERE class = a.class AND id bitsCN.com
分组后查找每组的前N条记录语句 Java代码 考你一条sql语句 如有表 student id name age class 1 张1 15 1 2 张2 15 1 3 张3 15 1 4 张4 15 2 5 张5 15 2 6 张6 15 2 7 张7 15 3 8 张8 15 3 9 张9 15 3 10 张10 15 5 11 张11 15 5
现在想得到每个班级的前2名学生资料 根据题意是,按class分组,然后取id靠前的两名,相信大多数人都能想到基本组合: SELECT a.* FROM student a ORDER BY a.class, a.id; 另加:Limit 0,2来配合。 (注:MYSQL 中没有top n的写法,取代的是LIMIT。) Limit 0,n只能取到最前的n位,但如何能取到每个班的前两位呢,就无从下手了。 下面我来具体分析一下这题的解法: 1、获取每个class的前两位: SELECT a.* FROM student a WHERE ( SELECT COUNT(*) FROM student WHERE class = a.class AND id bitsCN.com
推荐阅读
-
mysql实现每组取前N条记录的sql,以及后续的组数据量限制
-
分组后查找每组的前N条记录语句_MySQL
-
分组后,查找(前,后)N条记录
-
MySQL分组排序取前N条记录以及生成自动数字序列--groupby后limit外加rownumber_MySQL
-
MySQL分组排序取前N条记录以及生成自动数字序列的SQL_MySQL
-
MySQL分组排序取前N条记录以及生成自动数字序列--groupby后limit外加rownumber_MySQL
-
mysql使用GROUP BY分组实现取前N条记录的方法_MySQL
-
[MySQL]分组排序取前N条记录以及生成自动数字序列,类似groupby后limit_MySQL
-
[MySQL]分组排序取前N条记录以及生成自动数字序列,类似groupby后limit_MySQL
-
MySQL分组排序取前N条记录 以及 生成自动数目字序列 的SQL