[笔试题] 使用 SQL 语句查询学生科目成绩都大于 80 分的学生姓名

发布时间:2024-02-08 19:00

笔记题目

查询 score 表中学生科目成绩都大于 80 分的学生姓名
\"[笔试题]

建表与导入数据

-- 建表
CREATE TABLE `score` (
  `id` int(10) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `score` int(5) DEFAULT NULL,
  `course` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;

-- 导入数据
INSERT INTO `score` VALUES (1, \'张三\', 78, \'语文\');
INSERT INTO `score` VALUES (2, \'张三\', 82, \'数学\');
INSERT INTO `score` VALUES (3, \'李四\', 80, \'语文\');
INSERT INTO `score` VALUES (4, \'李四\', 53, \'数学\');
INSERT INTO `score` VALUES (5, \'王五\', 81, \'语文\');
INSERT INTO `score` VALUES (6, \'王五\', 91, \'数学\');
INSERT INTO `score` VALUES (7, \'王五\', 100, \' 英语\');
INSERT INTO `score` VALUES (8, \'赵六\', 100, \'语文\');
INSERT INTO `score` VALUES (9, \'赵六\', 90, \'数学\');

题解

思路:直接查询学生所有科目成绩都大于 80 分的学生比较困难,所以采用逆向思维,先过滤学生科目成绩小于 80 分的学生,剩下的都是学生科目成绩大于 80 分的学生,再按照学生姓名去重就可以结果。

select 
	distinct name 
from score 
where name not in (
		select name from score where score < 80
)

执行 SQL,查询结果如下所示:
\"[笔试题]

ItVuer - 免责声明 - 关于我们 - 联系我们

本网站信息来源于互联网,如有侵权请联系:561261067@qq.com

桂ICP备16001015号