学生信息表(学号,姓名,性别,班级)
课程信息表(课程编号,课程名称)
学生成绩表(学号,课程编号,分数)
s001,c1,89
1、查询学号为s001的学生的学号,姓名,课程编号,分数
select 学生信息表.学号,姓名,课程编号,分数
from 学生信息表,学生成绩表
where 学生信息表.学号=学生成绩表.学号 and 学生信息表.学号=‘s001’
select 学生信息表.学号,姓名,课程编号,分数
from 学生信息表 inner join 学生成绩表 on 学生信息表.学号=学生成绩表.学号
where 学生信息表.学号=‘s001’
2、查询语文课的平均分
select avg(score)
from 学生成绩表 inner join 课程信息表 on 学生成绩表.课程编号= 课程信息表.课程编号
where 课程名称=‘语文’
select avg(score)
from 学生成绩表
where 课程编号 in (select 课程编号 from 课程信息表 where 课程名称=‘语文’)
连接查询
嵌套查询
能嵌套绝不连接
3、查询学生的姓名,课程名、分数
select 姓名,课程名、分数
from 学生信息表 inner join 学生成绩表 on 学生信息表.学号=学生成绩表.学号
inner join 课程信息表 on 课程信息表.课程编号=学生成绩表.课程编号
select 姓名,课程名、分数
from 学生信息表,学生成绩表,课程信息表
where 学生信息表.学号=学生成绩表.学号 and 课程信息表.课程编号=学生成绩表.课程编号
分组查询
4、查询不同性别的平均分
select 性别,avg(分数)
from 学生信息表,学生成绩表
where 学生信息表.学号=学生成绩表.学号
group by 性别
5、查询每个学生学号和平均分
select 学号,avg(分数)
from 学生信息表,学生成绩表
where 学生信息表.学号=学生成绩表.学号
group by 学号
6、查询平均分高于60分的同学的学号
select 学号,avg(分数)
from 学生信息表,学生成绩表
where 学生信息表.学号=学生成绩表.学号
group by 学号
having avg(分数)>60
7、查询平均分高于60分的男同学的学号
select 学号,avg(分数)
from 学生信息表,学生成绩表
where 学生信息表.学号=学生成绩表.学号 and 性别=‘男’
group by 学号
having avg(分数)>60