10-23 查询平均成绩以上的课程(MSSQL)

这篇具有很好参考价值的文章主要介绍了10-23 查询平均成绩以上的课程(MSSQL)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本题目要求编写SQL语句,
查询每个同学超过他选修的平均成绩的课程。

请使用:
1)用相关子查询实现
2)使用派生表实现。

表结构:

请在这里写定义表结构的SQL语句。例如:

-- 课程表
CREATE TABLE  cou  (  
   cno  char(4) NOT NULL,
   cname  nvarchar(30) NOT NULL,
   credit  smallint DEFAULT NULL,
   ptime  char(5) DEFAULT NULL,
   teacher  nvarchar(10) DEFAULT NULL,
  PRIMARY KEY ( cno )
);
-- 学生选课成绩表
CREATE TABLE  sc  (  
   sno  char(4) NOT NULL,  -- 学生学号
   cno  char(4) NOT NULL,  -- 课程号
   grade  decimal(4,1) DEFAULT NULL,
  PRIMARY KEY ( sno , cno ),
  CONSTRAINT  fk_sc_cno  FOREIGN KEY ( cno ) REFERENCES  cou  ( cno )

表样例

请在这里给出上述表结构对应的表样例。例如

cou表:

10-23 查询平均成绩以上的课程(MSSQL),(3+2)专科段数据库原理及应用专项练习(2023版),数据库,mysql,sql,sqlserver

 sc表:

10-23 查询平均成绩以上的课程(MSSQL),(3+2)专科段数据库原理及应用专项练习(2023版),数据库,mysql,sql,sqlserver

输出样例:

请在这里给出输出样例。例如:

10-23 查询平均成绩以上的课程(MSSQL),(3+2)专科段数据库原理及应用专项练习(2023版),数据库,mysql,sql,sqlserver

 思路:

 将sc表和cou表连接起来,然后where条件为grade大于平均成绩文章来源地址https://www.toymoban.com/news/detail-736432.html

select a.sno 学号,cou.cname 课程名,a.grade 成绩
from sc a join cou
on a.cno=cou.cno
where a.grade >
(select avg(b.grade) from sc b where a.sno=b.sno) 
order by grade

到了这里,关于10-23 查询平均成绩以上的课程(MSSQL)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包