专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > SQL

用一条SQL语句查出每门课都大于80分的学生的名称

发布时间:2010-05-20 14:01:29 文章来源:www.iduyao.cn 采编人员:星星草
用一条SQL语句查出每门课都大于80分的学生的姓名

用一条SQL语句查出每门课都大于80分的学生的姓名,数据表结构如下:

建表SQL如下:

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for grade
-- ----------------------------
DROP TABLE IF EXISTS `grade`;
CREATE TABLE `grade` (
  `name` varchar(255) NOT NULL,
  `class` varchar(255) NOT NULL,
  `score` tinyint(4) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

-- ----------------------------
-- Records of grade
-- ----------------------------
INSERT INTO `grade` VALUES ('张三', '语文', '81');
INSERT INTO `grade` VALUES ('张三', '数学', '75');
INSERT INTO `grade` VALUES ('李四', '语文', '76');
INSERT INTO `grade` VALUES ('李四', '数学', '90');
INSERT INTO `grade` VALUES ('王五', '语文', '81');
INSERT INTO `grade` VALUES ('王五', '数学', '100');
INSERT INTO `grade` VALUES ('王五', '英语', '90');
SET FOREIGN_KEY_CHECKS=1;

 

查询每门课都大于80分的同学的姓名:

SELECT DISTINCT name FROM grade WHERE name NOT IN(SELECT DISTINCT name FROM grade WHERE score <=80);

  更简单的:

SELECT name FROM grade GROUP BY name HAVING MIN(score) > 80;

 

查询平均分大于80的学生的姓名:

SELECT name FROM (SELECT COUNT(*) AS t,SUM(score) AS num,name FROM `grade` GROUP BY name) AS a WHERE a.num > 80*t;

 更简单的:

select name, avg(score) as sc from grade g1 group by name having avg(score)>80 ;

 

1楼陶子
select name, avg(score) as sc from grade g1 group by name having avg(score)gt;80 ;
Re: praglody
@陶子,感谢指导
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: