--统计函数:
--count总数、max最大、min最小、avg平均、sum求和
select * from Student
--求出 学生表中的数据总条数
--count:求数据总条数
select count(*) from Student
--查询学生表中最大的年龄
select max(sage) from Student;
--查询最小的年龄
select min(sage) from Student;
--求组所有人的年龄总和
select sum(sage) from Student;
--求出平均年龄
select avg(sage) from Student;
--子查询
--查询所有年龄大于平均年龄的学生信息
select sage from Student where sage>(
select avg(sage) from Student
)
--分组查询:group by
--按照性别分组查询
select ssex from Student group by ssex
--查询每个地址的 平均年龄
select saddress,avg(sage) from Student group by saddress
--查询 男生 和 女生的平均年龄
select ssex,avg(sage) from Student group by ssex
--having:分组后的 过滤查询
--where:分组前的 条件查询
--根据性别查询出平均年龄大于14岁的
select ssex,avg(sage) from Student group by ssex
having avg(sage)>14
--查询男生
select * from Student where ssex='男'
--联表查询
/*
select * from 表1 别名
inner join 表2 别名
on 联表条件
*/
--inner join 查询出两个表中都有的数据
--查询每一个学生的信息 以及考试成绩
select * from Student a
inner join Score b
on a.sid=b.sid;
--查询学生学号,姓名,性别,年龄,地址,机试,笔试
select Student.sid,sname,ssex,sage,saddress,js,bs from Student
inner join Score
on Student.sid=Score.sid
where Student.sid=1
--全联
select Student.sid,sname,ssex,sage,saddress,js,bs from Student
full join Score
on Student.sid=Score.sid
--left join:查询数据以第一个表为标准
select * from Student a
left join Score b
on a.sid = b.sid
--right join:
--查询所有学生的学号,姓名,机试,笔试。起别名
select a.sid as 学号,sname as 姓名,js as 机试,bs as 笔试 from Student a
right join Score b
on a.sid=b.sid
--经典示例
select 学号=a.sid ,sname as 姓名,js 机试,bs as '笔试' from Student a
right join Score b
on a.sid=b.sid