news 2026/4/15 20:44:33

软件测试面试题中的sql题目

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
软件测试面试题中的sql题目

1.学生表(学生id,姓名,性别,分数)student(s_id,name,sex,score)

班级表(班级id,班级名称)class(c_id,c_name)

学生班级表(班级id,学生id)student_class(s_id,c_id)

1.查询一班得分在80分以上的学生

2.查询所有班级的名称,和所有版中女生人数和女生的平均分

题解:

  1. 1 .select * from student where score> 80 and s_id

  2. in ( select sid from student_class where c_id=( select c_id from class where c_name= '一班' ))

  3. 2 .select c.c_name,女生人数= sum (s.s_id),平均分= avg (s.score) from classes c

  4. inner join student_class sc on sc.c_id=c.c_id

  5. inner join students s on s.s_id=sc.s_idwhere s.sex= '女' group by c.c_name

    2.一道SQL语句面试题,关于group by表内容:

    info 表
    1. date result

    2. 2005-05-09 win

    3. 2005-05-09 lose

    4. 2005-05-09 lose

    5. 2005-05-09 lose

    6. 2005-05-10 win

    7. 2005-05-10 lose

    8. 2005-05-10 lose

    9. 如果要生成下列结果, 该如何写sql语句?

    10. win lose

    11. 2005-05-09 2 2

    12. 2005-05-10 1 2

    13. 答案:

    14. ( 1 ) select date , sum ( case when result = "win" then 1 else 0 end ) as "win",

    15. sum ( case when result = "lose" then 1 else 0 end ) as "lose" from info group by date ;

    16. ( 2 ) select a.date, a.result as win, b.result as lose from

    17. ( select date , count ( result ) as result from info where result = "win" group by date ) as a

    18. join

    19. ( select date , count ( result ) as result from info where result = "lose" group by date ) as b

    20. on a.date = b.date; 2.学生成绩表(stuscore):

      3.表中有A B C三列,用SQL语句实现:当A列大于B列时选择A列否则选择B列,当B列大于C列时选择B列否则选择C列

      select ( case when a > b then a else b end ), ( case when b > c then b else c end ) from table ;

      4.有一张表,里面有3个字段:语文,数学,英语。其中有3条记录分别表示语文70分,数学80分,英语58分,请用一条sql语句查询出这三条记录并按以下条件显示出来(并写出您的思路):?

      大于或等于80表示优秀,大于或等于60表示及格,小于60分表示不及格。?

      显示格式:?

      语文 数学 英语?

      及格 优秀 不及格?

      1. ------------------------------------------

      2. select

      3. (case when 语文>=80 then '优秀'

      4. when 语文>=60 then '及格'

      5. else '不及格') as 语文,

      6. (case when 数学>=80 then '优秀'

      7. when 数学>=60 then '及格'

      8. else '不及格') as 数学,

      9. (case when 英语>=80 then '优秀'

      10. when 英语>=60 then '及格'

      11. else '不及格') as 英语,

      12. from table

      5.姓名:name 课程:subject 分数:score 学号:stuid

      1. 张三 数学 89 1

      2. 张三 语文 80 1

      3. 张三 英语 70 1

      4. 李四 数学 90 2

      5. 李四 语文 70 2

      6. 李四 英语 80 2

        题解:

        1.计算每个人的总成绩并排名(要求显示字段:姓名,总成绩)
        答案:select name,sum(score) as allscore from stuscore group by name order by allscore

        2.计算每个人的总成绩并排名(要求显示字段: 学号,姓名,总成绩)
        答案:select distinct t1.name,t1.stuid,t2.allscore from stuscore t1,( select stuid,sum(score) as allscore from stuscore group by stuid)t2where t1.stuid=t2.stuidorder by t2.allscore desc

        3.计算每个人单科的最高成绩(要求显示字段: 学号,姓名,课程,最高成绩)
        答案:select t1.stuid,t1.name,t1.subject,t1.score from stuscore t1,(select stuid,max(score) as maxscore from stuscore group by stuid) t2where t1.stuid=t2.stuid and t1.score=t2.maxscore

        4.计算每个人的平均成绩(要求显示字段: 学号,姓名,平均成绩)
        答案:select distinct t1.stuid,t1.name,t2.avgscore from stuscore t1,(select stuid,avg(score) as avgscore from stuscore group by stuid) t2where t1.stuid=t2.stuid

        5.列出各门课程成绩最好的学生(要求显示字段: 学号,姓名,科目,成绩)
        答案:select t1.stuid,t1.name,t1.subject,t2.maxscore from stuscore t1,(select subject,max(score) as maxscore from stuscore group by subject) t2where t1.subject=t2.subject and t1.score=t2.maxscore

        6.列出各门课程成绩最好的两位学生(要求显示字段: 学号,姓名,科目,成绩)
        答案:select distinct t1.* from stuscore t1 where t1.id in (select top 2 stuscore.id from stuscore where subject = t1.subject order by score desc) order by t1.subject

        7.统计如下:学号 姓名 语文 数学 英语 总分 平均分
        答案:select stuid as 学号,name as 姓名,sum(case when subject=’语文’ then score else 0 end) as 语文,sum(case when subject=’数学’ then score else 0 end) as 数学,sum(case when subject=’英语’ then score else 0 end) as 英语,sum(score) as 总分,(sum(score)/count(*)) as 平均分from stuscoregroup by stuid,name order by 总分desc

        8.列出各门课程的平均成绩(要求显示字段:课程,平均成绩)
        答案:select subject,avg(score) as avgscore from stuscoregroup by subject

        9.列出数学成绩的排名(要求显示字段:学号,姓名,成绩,排名)
        答案:

        declare @tmp table(pm int,name varchar(50),score int,stuid int)

        insert into @tmp select null,name,score,stuid from stuscore where subject=’数学’ order by score desc

        declare @id int

        set @id=0;

        update @tmp set @id=@id+1,pm=@id

        select * from @tmp

        oracle:

        select DENSE_RANK () OVER(order by score desc) as row,name,subject,score,stuid from stuscore where subject=’数学’order by score desc

        ms sql(最佳选择)

        select (select count(*) from stuscore t1 where subject =’数学’ and t1.score>t2.score)+1 as row ,stuid,name,score from stuscore t2 where subject =’数学’ order by score desc

        10.列出数学成绩在2-3名的学生(要求显示字段:学号,姓名,科目,成绩)
        答案:select t3.* from(select top 2 t2.* from (select top 3 name,subject,score,stuid from stuscore where subject=’数学’order by score desc) t2 order by t2.score) t3 order by t3.score desc

        11.求出李四的数学成绩的排名
        答案:

        declare @tmp table(pm int,name varchar(50),score int,stuid int)insert into @tmp select null,name,score,stuid from stuscore where subject=’数学’ order by score descdeclare @id intset @id=0;update @tmp set @id=@id+1,pm=@idselect * from @tmp where name=’李四’

        12.统计如下:课程 不及格(0-59)个 良(60-80)个 优(81-100)个
        答案:select subject, (select count() from stuscore where score<60 and subject=t1.subject) as 不及格,(select count() from stuscore where score between 60 and 80 and subject=t1.subject) as 良,(select count(*) from stuscore where score >80 and subject=t1.subject) as 优from stuscore t1 group by subject

        13.统计如下:数学:张三(50分),李四(90分),王五(90分),赵六(76分)
        答案:

        declare @s varchar(1000)set @s=”select @s =@s+’,’+name+’(‘+convert(varchar(10),score)+’分)’ from stuscore where subject=’数学’ set @s=stuff(@s,1,1,”)print ‘数学:’+@s

        14.计算科科及格的人的平均成绩
        答案:select distinct t1.stuid,t2.avgscore from stuscore t1,(select stuid,avg(score) as avgscore from stuscore group by stuid ) t2,(select stuid from stuscore where score<60 group by stuid) t3 where t1.stuid=t2.stuid and t1.stuid!=t3.stuid;

        select name,avg(score) as avgscore from stuscore s where (select sum(case when i.score>=60 then 1 else 0 end) from stuscore i where i.name= s.name)=3 group by name

        1. 用一条SQL 语句 查询出每门课都大于80 分的学生姓名

        name kecheng fenshu

        张三 语文 81

        张三 数学 75

        李四 语文 76

        李四 数学 90

        王五 语文 81

        王五 数学 100

        王五 英语 90

        A: select distinct name from table where name not in (select distinct name from table where fenshu<=80)

        select name from table group by name having min(fenshu)>80

        总结:

        感谢每一个认真阅读我文章的人!!!

        作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

        软件测试面试文档

        我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

        视频文档获取方式:
        这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

        版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
        网站建设 2026/4/10 12:27:41

        1小时打造自动刷新工具原型

        快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 快速开发一个自动刷新工具原型&#xff0c;核心功能&#xff1a;1. 最基本的时间设置&#xff1b;2. 开关控制&#xff1b;3. 当前状态显示。使用最简代码实现&#xff0c;不考虑异…

        作者头像 李华
        网站建设 2026/4/15 0:10:57

        AI如何帮你自动生成MYSQL UPDATE语句?

        快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个AI辅助工具&#xff0c;能够根据用户输入的表名、字段名和更新条件&#xff0c;自动生成正确的MYSQL UPDATE语句。要求支持多条件更新、批量更新等常见场景&#xff0c;并…

        作者头像 李华
        网站建设 2026/4/11 14:17:11

        传统排错vsAI辅助:解决GPG问题效率对比

        快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个GPG问题解决效率对比工具&#xff0c;展示传统排错流程(手动检查环境变量、路径配置、版本兼容性)与AI辅助解决方案的时间成本差异。工具应包含计时功能、步骤记录和效率分…

        作者头像 李华
        网站建设 2026/4/15 6:59:09

        如何用AI自动搭建私有GITHUB镜像站

        快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个基于AI的自动化脚本&#xff0c;用于搭建私有GITHUB镜像站。脚本应包含以下功能&#xff1a;1. 自动从GITHUB同步指定仓库到本地服务器&#xff1b;2. 支持定时同步和增量…

        作者头像 李华
        网站建设 2026/4/14 20:08:06

        小白必看:NumPy版本问题快速解决指南

        快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个交互式学习模块&#xff1a;1) 用动画解释NumPy版本差异导致错误的原因&#xff1b;2) 提供三个简单解决方案的可执行示例&#xff1a;使用conda降级、修改import语句、替…

        作者头像 李华
        网站建设 2026/4/10 15:01:23

        InSAR学习中一些有用的链接

        文章来源&#xff1a; Natural Hazards Remote Sensing Lab https://gsprs-pku.github.io/links/ &#xff08;文中文件下载链接&#xff1a;https://pan.quark.cn/s/ec0dbd1f1c0e&#xff09; InSAR 原理 NASA (NISAR 手册) https://nisar.jpl.nasa.gov/system/docume…

        作者头像 李华