Sweet-kai 2016-06-22 02:56 采纳率: 33.3%
浏览 2378
已采纳

sql高难度笔试题,4个表,一条查询语句

今天笔试最后 一道sql问题

班级表A:字段(班级名称、班级)
学生表B:字段(学号、姓名)
课程表C:字段(课程号、课程名)
选课表D:字段(学号、课程号、成绩)
问题:用一条查询语句查询 "一班"比"二班"法语平均成绩高的学生信息

  • 写回答

3条回答 默认 最新

  • 中国风 博客专家认证 2016-06-22 03:12
    关注

    学生表B 少了"班级"栏位

    SELECT b.*
    FROM A
    INNER JOIN B ON A.班级 = B.班级
    INNER JOIN D ON D.学号 = B.学号
    INNER JOIN ( SELECT D.课程号 ,
    AVG(D.成绩) AS 成绩
    FROM A
    INNER JOIN B ON A.班级 = B.班级
    INNER JOIN D ON D.学号 = B.学号
    INNER JOIN C ON C.课程号 = D.课程号
    WHERE A.班级名称 = '二班'
    AND C.课程名 = '法语'
    ) AS C ON C.课程号 = D.课程号 AND c.成绩<d.成绩
    WHERE A.班级名称 = '二'
    ;

    ;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 python中合并修改日期相同的CSV文件并按照修改日期的名字命名文件
  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员