zoukankan      html  css  js  c++  java
  • 一个1级分组基础上同时进行2级分组的SQL面试题


    示例1:测试数据:

    SQL> select * from score;

            ID CLASS STUDENT COURSE      SCORE

    ---------- ----- ------- ------ ----------

             1 一 张三 数学           90

             2 一 张三 语文           89

             3 一 李四 数学           26

             4 一 李四 语文           31

             5 二 王五 数学           90

             6 二 王五 语文           80

             7 二 赵六 数学           70

             8 二 赵六 语文           79

    8 rows selected

    实现一个SQL,要求统计一二班考试总人数,总成绩,语文考试总成绩,参加考试人数?

    解:

    SQL> select class,

      2         sum(score),

      3         count(distinct student),

      4         sum(case

      5               when course = '语文' then

      6                score

      7               else

      8                null

      9             end)

    10    from score

    11   group by class;

    CLASS SUM(SCORE) COUNT(DISTINCTSTUDENT)   SUM(CASEWHENCOURSE='语文'THENS

    ----- ---------- ---------------------- ------------------------------

    二           319                      2                            159

    一           236                      2                            120

    SQL> select t1.class,

      2         sum(t1.score),

      3         count(distinct t1.student),

      4         (select sum(t2.score)

      5            from score t2

      6           where t2.course = '语文'

      7             and t2.class = t1.class)

      8    from score t1

      9   group by class;

    CLASS SUM(T1.SCORE) COUNT(DISTINCTT1.STUDENT) (SELECTSUM(T2.SCORE)FROMSCORET

    ----- ------------- ------------------------- ------------------------------

    二              319                         2                            159

    一              236                         2                            120

    在这个子查询中,case when相当于一个子查询,在group by class分组的基础上进行二次筛选,最终可以求出语文总成绩。

    示例二:

    已知四张表,第一张为用户表,里面有 小明 id为1,小红 id为2,小王 id为3, 小明 id为4, 小张 id为5这五个人。
    第二张为数学作业表,通过用户id,然后用count可以获取每个用户数学作业完成总数,
    第三张为语文作业表,通过用户id,然后用count可以获取每个用户语文作业完成总数,
    第四张为英语作业表,通过用户id,然后用count可以获取每个用户英语作业完成总数,
    现在需要获取五个用户的数学 ,语文, 英语 三门作业完成的总数,然后排出前三名,
    返回给后台这三个人的姓名,和完成总数

    解:

    select *

    from (select t.name, (m + y + e) as sum

    from (select t1.name,

    (select count(1) from t2 where t1.id = t2.id) as m,

    (select count(1) from t3 where t1.id = t3.id) as y,

    (select count(1) from t4 where t1.id = t4.id) as e

    from t1) t

    order by sum desc)

    where rownum < 4;

  • 相关阅读:
    osharp3引入事务后操作结果类别的调整
    Code First 迁移
    表达式拼接Expression<Func<IEntityMapper, bool>> predicate
    ASP.NET中Session的sessionState 4种mode模式
    EF Code First Migrations数据库迁移
    啊里大鱼短信发送API
    asp.net服务器控件的生命周期
    osharp3使用经验:整合DbContextScope 文章 1
    关于MarshalByRefObject的解释
    数据库操作事务IsolationLevel 枚举
  • 原文地址:https://www.cnblogs.com/wcwen1990/p/7601196.html
Copyright © 2011-2022 走看看