SQL高级查询

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
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值