一.学生表(学生id,姓名,性别,分数)student(s_id,name,sex,score) 班级表(班级id,班级名称)class(c_id,c_name) 学生班级表(班级id,学生id)student_class(s_id,c_id)(考察三表联查) 1.查询一班得分在80分以上的学生。
答:select * from student s where score > 80 and s.s_id in (select sid from student_class where c_id=(select c_id from class where c_name='一班' )
2.查询所有班级的名称,和所有班中女生人数和女生的平均分
答:select c.c_name,女生人数=sum(s.s_id),女生平均分=avg(s.score) from student inner join student_class sc on s.s_id = sc.s_id and inner join class c on sc.c_id = s.c_id where s.sex='女'
二.一道SQL语句面试题,关于group by表内容:(考察group by 和 case when ) info 表 date result 2005-05-09 win 2005-05-09 lose 2005-05-09 lose 2005-05-09 lose 2005-05-10 win 2005-05-10 lose 2005-05-10 lose 如果要生成下列结果, 该如何写sql语句? win lose 2005-05-09 2 2 2005-05-10 1 2 答:select date,sum(case when result='win' then 1 else 0 end) as 'win' ,sum(case when result='lose' then 1 else o end)as 'lose' from info group by date
三.表中有A B C三列,用SQL语句实现:当A列大于B列时选择A列否则选择B列,当B列大于C列时选择B列否则选择C列(考察case when)(case when xxx then xxx else xxxx end)
答:select (case when A >B then A else B),(case when B >C then B else C) from table;
四.有一张表,里面有3个字段:语文,数学,英语。其中有3条记录分别表示语文70分,数学80分,英语58分,请用一条sql语句查询出这三条记录并按以下条件显示出来(并写出您的思路)(考察case when): 大于或等于80表示优秀,大于或等于60表示及格,小于60分表示不及格。 显示格式:语文 数学 英语 及格 优秀 不及格
答:select (case when '语文'>=80 then '优秀' when '语文' >=60 then '及格' else '不及格' end) as '语文' ,(case when '数学'>=80 then '优秀' when '数学' >=60 then '及格' else '不及格' end) as '数学',(case when '英语'>=80 then '优秀 when '英语' >=60 then '及格' else '不及格' end)as '英语' from table
五.姓名:name 课程:subject 分数:score 学号:stuid ,表名:stuscore
张三 数学 89 1 张三 语文 80 1 张三 英语 70 1 李四 数学 90 2 李四 语文 70 2 李四 英语 80 2
题目:1.计算每个人的总成绩并排名(要求显示字段:姓名,总成绩)(根据姓名进行分组)
答:select sum(score) as allscore,name from stuscore group by name order by allscore ;
2.计算每个人的总成绩并排名(要求显示字段: 学号,姓名,总成绩)(根据学号进行分组)
答:SELECT DISTINCT stuid,NAME,SUM(score) AS allscore FROM stuscore GROUP BY stuid ORDER BY allscore ;
3.计算每个人单科的最高成绩(要求显示字段: 学号,姓名,课程,最高成绩)
答:select stuid,name,subject ,max(score) from stuscore group by name
4.计算每个人的平均成绩(要求显示字段: 学号,姓名,平均成绩)
答:select stuid,name,avg(score) from stuscore group by name
5.列出各门课程成绩最好的学生(要求显示字段: 学号,姓名,科目,成绩)
答:SELECT t1.stuid,t1.name,t1.subject,t2.maxscore FROM stuscore t1,(SELECT SUBJECT,MAX(score) AS maxscore FROM stuscore GROUP BY SUBJECT) t2 WHERE t1.subject = t2.subject AND t1.score=t2.maxscore
6.列出各门课程成绩最好的两位学生(要求显示字段: 学号,姓名,科目,成绩)
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
my 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