• 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)


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


  • 相关阅读:
    屠蛟之路_重伤的屠蛟俊_ThirdDay
    屠蛟之路_重登数据库大山_SecondDay
    屠蛟之路_你的名字_FirstDay
    Beta版本冲刺计划及安排
    软件工程作业1203
    导师互选系统 Alpha版冲刺总结
    屠龙之路_项目测试
    【Alpha】十天屠龙记
    屠龙之路_冲刺总结随笔
    My97日历控件常用功能记录
  • 原文地址:https://www.cnblogs.com/jessonlv/p/4387990.html
Copyright © 2020-2023  润新知