max等聚合函数和group by 使用时,需要HAVING,否则查出的有误

-- ----------------------------
-- Table structure for score
-- ----------------------------
DROP TABLE IF EXISTS `score`;
CREATE TABLE `score`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `subject` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `no` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `score` double(12, 4) NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 10 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of score
-- ----------------------------
INSERT INTO `score` VALUES (1, '语文', '王一', '001', 99.0000);
INSERT INTO `score` VALUES (2, '语文', '周二', '002', 98.0000);
INSERT INTO `score` VALUES (3, '语文', '徐三', '003', 97.0000);
INSERT INTO `score` VALUES (4, '数学', '王一', '001', 91.0000);
INSERT INTO `score` VALUES (5, '数学', '周二', '002', 96.0000);
INSERT INTO `score` VALUES (6, '数学', '徐三', '003', 92.0000);
INSERT INTO `score` VALUES (7, '英语', '王一', '001', 76.0000);
INSERT INTO `score` VALUES (8, '英语', '周二', '002', 66.0000);
INSERT INTO `score` VALUES (9, '英语', '徐三', '003', 86.0000);

SELECT
	s.NO,
	s.NAME,
	s.SUBJECT,
	MAX(s.score) '最高分' 
FROM
	( SELECT NO, NAME, SUBJECT, score FROM score HAVING 1 = 1 ORDER BY score.score DESC ) s 
WHERE
	1 = 1 
GROUP BY
SUBJECT

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值