2019.4.4聚合函数

在这里插入图片描述

count() 用于计算数量

在这里插入图片描述
count(*) 查询某列共多少个值
在这里插入图片描述

为了列名方便观看,一般要取别名。

select count(*) count from student where mingzu='汉族';

在这里插入图片描述

在这里插入图片描述


sum() 用于计算某列的和

在这里插入图片描述

select sum(列名) from user;

同样的 sum也可以取别名
在这里插入图片描述

avg() 计算某列的平均值

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

max()、min() 求某列的最大、最小值。

在这里插入图片描述

综合:
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

group by

在这里插入图片描述

在这里插入图片描述

实例:
在这里插入图片描述
排序的时候 排序的列名应该是已经查询出来的别名。

在这里插入图片描述
若要加条件,这个where应该加在表名的后面。

在分组,排序的时候,先去掉多余的数据,留下有用的,再进行分组和排序。

Having

在这里插入图片描述

having尽量少用 因为它要遍历整张表的所有数据,在整张表全部进行运算,影响效率。

强烈建议多使用子查询
having的用法
https://www.cnblogs.com/lao-tang/p/6398577.html

查询语句的执行顺序:

在这里插入图片描述

什么是SQL优化?

sql优化指的是在运行时 先筛选掉大的 再在小的里面进行二次筛选 然后分组 ,排序。要按照这个顺序去写sql代码

关联查询

在这里插入图片描述

示例:

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

笛卡尔积

在这里插入图片描述

示例:
在这里插入图片描述

上面的两个表,若不写条件 where 就会产生下面结果:

在这里插入图片描述

等值连接

在这里插入图片描述

内连接

在这里插入图片描述

外连接(重点 语法要背)

在这里插入图片描述

在这里插入图片描述
把左边的表作为主表,右边的表的数据 把满足条件的结果拼接到后边,主表的所有数据都要显示
意思是虽然左边的 用户D 没有id数值,但是外连接还是会把D显示出来,只是没有数据而已,而不是直接把D取消资格。

图上的蓝色线就是驱动条件

右连接:显示右边的全部数据,即使对应的左边的值为空,也一样显示
在这里插入图片描述

左连接:显示左边的全部条件,即使对应的右边的值为空,也一样显示
From table left outer join table

在这里插入图片描述

另一种写法
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

分页查询

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值