文档介绍:该【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');