0
点赞
收藏
分享

微信扫一扫

SQL高级查询

_铁马冰河_ 2022-05-04 阅读 30
java

v

5.统计函数:
--count总数、max最大、min最小、avg平均、sum求和
举例:
--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
    )


10.分组查询:group by

--地址分组
    select saddress from Student group by saddress;


--按照性别分组查询
    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='男'

11.联表查询
    /*
    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

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

举报

相关推荐

0 条评论