1 / 13
文档名称:

2025年SQL查询面试题与答案.docx

格式:docx   大小:32KB   页数:13页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

2025年SQL查询面试题与答案.docx

上传人:圭圭 2025/3/19 文件大小:32 KB

下载得到文件列表

2025年SQL查询面试题与答案.docx

相关文档

文档介绍

文档介绍:该【2025年SQL查询面试题与答案 】是由【圭圭】上传分享,文档一共【13】页,该文档可以免费在线阅读,需要了解更多关于【2025年SQL查询面试题与答案 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。









2025年SQL查询面试题与答案
SQL查询面试题与答案一
  ,关于group by表内容:
  2025-05-09 胜
  2025-05-09 胜
  2025-05-09 负
  2025-05-09 负










  2025-05-10 胜
  2025-05-10 负
  2025-05-10 负
  如果要生成下列结果, 该如何写sql语句?
  胜 负
  2025-05-09 2 2
  2025-05-10 1 2
  ------------------------------------------
  create table #tmp(rq varchar(10),shengfu nchar(1))
  insert into #tmp values('2025-05-09','胜')
  insert into #tmp values('2025-05-09','胜')
  insert into #tmp values('2025-05-09','负')
  insert into #tmp values('2025-05-09','负')
  insert into #tmp values('2025-05-10','胜')
  insert into #tmp values('2025-05-10','负')
  insert into #tmp values('2025-05-10','负')
  1)select rq, sum(case when shengfu='胜' then 1 else 0 end)'胜',sum(case when shengfu='负' then 1 else 0 end)'负' from #tmp group by rq
  2) select ,, from (
  select rq,勝=count(*) from #tmp where shengfu='胜'group by rq)N inner join
  (select rq,負=count(*) from #tmp where shengfu='负'group by rq)M on =
  3)select , 胜, 负 from
  (select col001,count(col001) a1 from temp1 where col002='胜' group by col001) a,










  (select col001,count(col001) b1 from temp1 where col002='负' group by col001) b
  where =
  
  表中有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 esle c end)
  from table_name
  :一个日期判断的sql语句?
  请取出tb_send表中日期(SendTime字段)为当天的所有记录?(SendTime字段为datetime型,包含日期与时间)
  ------------------------------------------
  select * from tb where datediff(dd,SendTime,getdate())=0
  ,里面有3个字段:语文,数学,英语。其中有3条记录分别表示语文70分,数学80分,英语58分,请用一条sql语句查询出这三条记录并按以下条件显示出来(并写出您的思路):
  大于或等于80表示优秀,大于或等于60表示及格,小于60分表示不及格。
  显示格式:
  语文 数学 英语
  及格 优秀 不及格
  ------------------------------------------
  select
  (case when 语文>=80 then '优秀'
  when 语文>=60 then '及格'
  else '不及格') as 语文,










  (case when 数学>=80 then '优秀'
  when 数学>=60 then '及格'
  else '不及格') as 数学,
  (case when 英语>=80 then '优秀'
  when 英语>=60 then '及格'
  else '不及格') as 英语,
  from table
  ,里面包含两个字段ID和IDValues,类型都是int型,并解释下两者的区别?
  ------------------------------------------
  用户临时表:create table #xx(ID int, IDValues int)
  系统临时表:create table ##xx(ID int, IDValues int)
  区别:
  用户临时表只对创建这个表的用户的Session可见,对其他进程是不可见的.
  当创建它的进程消失时这个临时表就自动删除.
  全局临时表对整个SQL Server实例都可见,但是所有访问它的Session都消失的时候,它也自动删除.
  ,他的`存储容量只受存储介质的限制,请问它是通过什么方式实现这种无限容量机制的。
  ------------------------------------------
  它的所有数据都存储在数据文件中(*.dbf),所以只要文件够大,SQL Server的存储容量是可以扩大的.
  SQL Server 2000 数据库有三种类型的文件:
  主要数据文件










  主要数据文件是数据库的起点,指向数据库中文件的其它部分。每个数据库都有一个主要数据文件。主要数据文件的推荐文件扩展名是 .mdf。
  次要数据文件
  次要数据文件包含除主要数据文件外的所有数据文件。有些数据库可能没有次要数据文件,而有些数据库则有多个次要数据文件。次要数据文件的推荐文件扩展名是 .ndf。
  日志文件
  日志文件包含恢复数据库所需的所有日志信息。每个数据库必须至少有一个日志文件,但可以不止一个。日志文件的推荐文件扩展名是 .ldf。
  
  从table1,table2中取出如table3所列格式数据,注意提供的数据及结果不准确,只是作为一个格式向大家请教。
  如使用存储过程也可以。
  table1
  月份mon 部门dep 业绩yj
  -------------------------------
  一月份 01 10
  一月份 02 10
  一月份 03 5
  二月份 02 8
  二月份 04 9
  三月份 03 8
  table2
  部门dep 部门名称dname










  --------------------------------
  01 国内业务一部
  02 国内业务二部
  03 国内业务三部
  04 国际业务部
  table3 (result)
  部门dep 一月份 二月份 三月份
  --------------------------------------
  01 10 null null
  02 10 8 null
  03 null 5 8
  04 null null 9
  ------------------------------------------
  1)
  select , as '一月份', as '二月份', as '三月份'
  from table1 a,table2 b,table2 c,table2 d
  where = and = '一月份' and
   = and = '二月份' and
   = and = '三月份' and
  2)
  select ,
  sum(case when =1 then else 0 end) as '一月份',
  sum(case when =2 then else 0 end) as '二月份',
  sum(case when =3 then else 0 end) as '三月份',
  sum(case when =4 then else 0 end) as '四月份',
  sum(case when =5 then else 0 end) as '五月份',
  sum(case when =6 then else 0 end) as '六月份',










  sum(case when =7 then else 0 end) as '七月份',
  sum(case when =8 then else 0 end) as '八月份',
  sum(case when =9 then else 0 end) as '九月份',
  sum(case when =10 then else 0 end) as '十月份',
  sum(case when =11 then else 0 end) as '十一月份',
  sum(case when =12 then else 0 end) as '十二月份',
  from table2 a left join table1 b on =
  
  一个表中的Id有多个记录,把所有这个id的记录查出来,并显示共有多少条记录数。
  ------------------------------------------
  select id, Count(*) from tb group by id having count(*)>1
  select * from(select count(ID) as count from table group by ID)T where >1
  SQL查询面试题与答案二
  1、查询不同老师所教不同课程平均分从高到低显示
  SELECT max(#) AS 教师ID,MAX() AS 教师姓名,# AS 课程ID,MAX() AS 课程名称,AVG(Score) AS 平均成绩
  FROM SC AS T,Course AS C ,Teacher AS Z
  where #=# and #=#
  GROUP BY #
  ORDER BY AVG(Score) DESC
  2、查询如下课程成绩第 3 名到第 6 名的学生成绩单:企业管理(001),马克思(002),UML (003),数据库(004)
  [学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩
  SELECT DISTINCT top 3
  # As 学生学号,










   AS 学生姓名 ,
   AS 企业管理,
   AS 马克思,
   AS UML,
   AS 数据库,
  ISNULL(,0) + ISNULL(,0) + ISNULL(,0) + ISNULL(,0) as 总分
  FROM Student,SC LEFT JOIN SC AS T1
  ON # = # AND # = '001'
  LEFT JOIN SC AS T2
  ON # = # AND # = '002'
  LEFT JOIN SC AS T3
  ON # = # AND # = '003'
  LEFT JOIN SC AS T4
  ON # = # AND # = '004'
  WHERE #=# and
  ISNULL(,0) + ISNULL(,0) + ISNULL(,0) + ISNULL(,0)
  NOT IN
  (SELECT
  DISTINCT
  TOP 15 WITH TIES
  ISNULL(,0) + ISNULL(,0) + ISNULL(,0) + ISNULL(,0)
  FROM sc
  LEFT JOIN sc AS T1
  ON # = # AND # = 'k1'
  LEFT JOIN sc AS T2
  ON # = # AND # = 'k2'
  LEFT JOIN sc AS T3
  ON # = # AND # = 'k3'
  LEFT JOIN sc AS T4
  ON # = # AND # = 'k4'
  ORDER BY ISNULL(,0) + ISNULL(,0) + ISNULL(,0) + ISNULL(,0) DESC);
  3、统计列印各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[ <60]
  SELECT # as 课程ID, Cname as 课程名称










  ,SUM(CASE WHEN score BETWEEN 85 AND 100 THEN 1 ELSE 0 END) AS [100 - 85]
  ,SUM(CASE WHEN score BETWEEN 70 AND 85 THEN 1 ELSE 0 END) AS [85 - 70]
  ,SUM(CASE WHEN score BETWEEN 60 AND 70 THEN 1 ELSE 0 END) AS [70 - 60]
  ,SUM(CASE WHEN score < 60 THEN 1 ELSE 0 END) AS [60 -]
  FROM SC,Course
  where #=#
  GROUP BY #,Cname;
  4、查询学生平均成绩及其名次
  SELECT 1+(SELECT COUNT( distinct 平均成绩)
  FROM (SELECT S#,AVG(score) AS 平均成绩
  FROM SC
  GROUP BY S#
  ) AS T1
  WHERE 平均成绩 > ) as 名次,
  S# as 学生学号,平均成绩
  FROM (SELECT S#,AVG(score) 平均成绩
  FROM SC
  GROUP BY S#
  ) AS T2
  ORDER BY 平均成绩 desc;
  5、查询各科成绩前三名的记录:(不考虑成绩并列情况)
  SELECT # as 学生ID,# as 课程ID,Score as 分数
  FROM SC t1
  WHERE score IN (SELECT TOP 3 score
  FROM SC
  WHERE #= C#
  ORDER BY score DESC
  )
  ORDER BY #;
  6、查询每门课程被选修的学生数
  select c#,count(S#) from sc group by C#;
  7、查询出只选修了一门课程的全部学生的学号和姓名










  select #,,count(C#) AS 选课数
  from SC ,Student
  where #=# group by # , having count(C#)=1;
  8、查询课程编号002的成绩比课程编号001课程低的所有同学的学号、姓名;
  Select S#,Sname from (select #,,score ,(select score from SC SC_2 where #=# and #='002') score2
  from Student,SC where #=# and C#='001') S_2 where score2
  9、查询所有课程成绩小于60分的同学的学号、姓名;
  select S#,Sname
  from Student
  where S# not in (select # from Student,SC where #=# and score>60);
  10、查询没有学全所有课的同学的学号、姓名;
  select #,
  from Student,SC
  where #=# group by #, having count(C#) <(select count(C#) from Course);
  11、查询至少有一门课与学号为1001的同学所学相同的同学的学号和姓名;
  select S#,Sname from Student,SC where #=# and C# in select C# from SC where S#='1001';
  12、查询至少学过学号为001同学所有一门课的其他同学学号和姓名;
  select distinct #,Sname
  from Student,SC
  where #=# and C# in (select C# from SC where S#='001');
  13、把SC表中叶平老师教的课的成绩都更改为此课程的平均成绩;
  update SC set score=(select avg()
  from SC SC_2
  where #=# ) from Course,Teacher where #=# and #=# and ='叶平');
  14、查询和1002号的同学学习的课程完全相同的其他同学学号和姓名;
  select S# from SC where C# in (select C# from SC where S#='1002')
  group by S# having count(*)=(select count(*) from SC where S#='1002');