zoukankan      html  css  js  c++  java
  • SQL语句面试题(IN、NOT IN、COUNT、GROUP BY)

    jessonlv-吕国栋原创文章,转载请注明出处:http://blog.csdn.net/jessonlv

    面试过程中遇到的面试题,主要考察SQL的联合查询,google了下,但是有一处错误,我修正了那一错误并分享给大家:

    问题描述:
    为管理岗位业务培训信息,建立3个表:
    S (S#,SN,SD,SA)   S#,SN,SD,SA 分别代表学号、学员姓名、所属单位、学员年龄
    C (C#,CN )        C#,CN       分别代表课程编号、课程名称
    SC ( S#,C#,G )    S#,C#,G     分别代表学号、所选修的课程编号、学习成绩

    要求实现如下5个处理:
      1. 使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名
      2. 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位
      3. 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位
      4. 使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位
      5. 查询选修了课程的学员人数
      6. 查询选修课程超过5门的学员学号和所属单位

    1. 使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名 
    --实现代码:

    SELECT S#,SD FROM S
    WHERE [S#] IN(
        SELECT [S#] FROM C,SC
        WHERE C.[C#]=SC.[C#]
            AND CN=N'税收基础')

    2. 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位

    --实现代码:

    SELECT S.SN,S.SD FROM S,SC
    WHERE S.[S#]=SC.[S#]
        AND SC.[C#]='C2'

    3. 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位

    --实现代码:

    SELECT SN,SD FROM S
    WHERE [S#] NOT IN(
        SELECT [S#] FROM SC 
        WHERE [C#]='C5')

    4. 使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位

    --实现代码:

    SELECT SN,SD FROM S
    WHERE [S#] IN(
        SELECT [S#] FROM SC 
            RIGHT JOIN C ON SC.[C#]=C.[C#]
        GROUP BY [S#]
        HAVING COUNT(*)=COUNT(DISTINCT [S#]))

    5. 查询选修了课程的学员人数

    --实现代码:

    SELECT 学员人数=COUNT(DISTINCT [S#]) FROM SC

    6. 查询选修课程超过5门的学员学号和所属单位

    --实现代码:

    SELECT SN,SD FROM S
    WHERE [S#] IN(
        SELECT [S#] FROM SC 
        GROUP BY [S#]
        HAVING COUNT(DISTINCT [C#])>5)


    以上为在参加面试的过程中搜集到的面试题,后续我会收集更多面试题,关键是收集后学习和总结,希望对所有有需要的人有所帮助,哦了。


  • 相关阅读:
    ORACLE NOLOGGING研究
    由2013星光大道总决赛同步程序猿怎样成功?
    configure: error: mysql configure failed. Please check config.log for more information.
    The 2014 ACM-ICPC Asia Mudanjiang Regional Contest(2014牡丹江区域赛)
    about service in android
    极客标签互动课程系列 - Javascript生成SVG动画素描特效
    sql -- 移除数据中的换行符和回车符
    前端project师必需知识点
    spring装配集合
    【java项目实践】具体解释Ajax工作原理以及实现异步验证username是否存在+源代码下载(java版)
  • 原文地址:https://www.cnblogs.com/jessonlv/p/4387990.html
Copyright © 2011-2022 走看看