要求查找到学校不同年级中每个年级的最高分人员信息,并列第一的学生信息都要查询出来
首先准备数据
DROP TABLE IF EXISTS `css`;
CREATE TABLE `css` (
`id` tinyint(20) NOT NULL,
`class` varchar(255) COLLATE utf8mb4_bin DEFAULT NULL,
`student` varchar(255) COLLATE utf8mb4_bin DEFAULT NULL,
`score` float(255,0) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;
INSERT INTO `css` VALUES (1, '一年级', '张三', 90);
INSERT INTO `css` VALUES (2, '一年级', '王二麻子', 20);
INSERT INTO `css` VALUES (3, '二年级', '李四', 50);
INSERT INTO `css` VALUES (4, '一年级', '赵六', 96);
INSERT INTO `css` VALUES (5, '二年级', '张郑', 90);
INSERT INTO `css` VALUES (6, '三年级', '张安安', 95);
INSERT INTO `css` VALUES (7, '三年级', '综一', 52);
INSERT INTO `css` VALUES (8, '三年级', '李思', 95);
分析:可以使用group by 对班级进行分组,再使用max函数找出每个年级的最高分数,所以可以这样写
SELECT class, max( score ) FROM css GROUP BY class
执行上面的语句可以得到如下结果
一年级 96
二年级 90
三年级 95
可以看出这样已经查询出每个年级对应的最高分,那根据这2个条件,再去表里查询对应年级和分数的学生信息即可
SELECT
*
FROM
css
WHERE
( class, score ) IN ( SELECT class, max( score ) FROM css GROUP BY class)
这样执行出来的结果就可以找到每个年级最高分的学生信息,同时并列第一的学生也可以查询到,结果如下
4 一年级 赵六 96
5 二年级 张郑 90
6 三年级 张安安 95
8 三年级 李思 95
注意:查询列中的字段如果不是group by的字段,那么需要对该字段使用聚合函数,所以这里使用max()找出最大值,而student字段是没法使用的,否则查询出来的就是多个,所以需要使用子查询