3.聚合与排序

本文介绍了SQL中的聚合查询,包括COUNT、SUM、AVG、MAX和MIN函数的使用,以及如何去除重复值。接着讲解了如何通过GROUP BY进行数据分组,HAVING用于设定分组条件。ORDER BY用于结果排序,可以指定升序或降序。最后,文章提供了练习题以巩固所学知识。
摘要由CSDN通过智能技术生成

1.对表的聚合查询-聚合函数

1.1聚合函数
  • COUNT:计算表中的记录数

  • SUM:计算表中某列数据的和

  • AVG:计算表中某列数据的平均值

  • MAX:计算表中数据的某列数据的最大值

  • MIN:计算表中数据的某列数据的最小值

    在这里插入图片描述

在这里插入图片描述

  • 使用聚合函数删除重复值

在这里插入图片描述

1.2常用法则
  • count(*)会得到包含NULL的数据行数,COUNT(column_name)会得到NULL之外的数据行数

  • 聚合函数会将NULL值排除在外,但COUNT(*)例外

  • MAX/MIN函数几乎适用于所有数据类型的列;SUM/AVG函数只适用于数值类型的列

  • 要计算值的种类时,可以在COUNT函数的参数中使用DISTINCT

  • 在聚合函数内部使用DISTINCT可以删除重复数据

2.对表进行分组-group by

  • group by 将现有的数据按照某列来汇总统计
-- 1.select 2.from 3.where 4.group by 
-- 前三项用于筛选数据,group by对筛选出的数据进行处理
SELECT column_name, aggregate_function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name
HAVING aggregate_function(column_name) operator value;

在这里插入图片描述

注意:

  1. 聚合键中包含NULL时,将单独作为一组数据进行处理

  2. select子句中出现的列名只能是group by中指定的列名(聚合键);当使用count等聚合函数时,可以出现在聚合函数中使用其他列名

  3. select子句中通过as来指定别名,但在group by中不能使用别名,在DBMS中,select子句在group by之后执行

  4. where指定筛选的记录(行)的条件,having指定分组的条件

3.为聚合结果指定条件-having

having对分组进行过滤,可以使用数字、聚合函数和聚合键

在这里插入图片描述

4. 对查询结果进行排序-order by

SELECT column_name,column_name
FROM table_name
ORDER BY column_name,column_name ASC|DESC;
-- desc为降序,asc为升序(默认)

在这里插入图片描述

  • 多个排序键:先按sale_price升序排序,当sale_price值相同时,再按product_id升序排序

  • 排序键包含NULL时,NULL会再开头或末尾汇总

  • order by中列名可以为别名:SQL语句的执行顺序——from、where、group by、having、select、order by,select语句在group by之后,在order by之前,当order by中使用别名时,已经知道select中设置的别名了,但group by使用别名时还不知道别名

5.练习题

1.在这里插入图片描述

答:
1)where和group by的顺序不对

2)select选择的列只能是聚合键或聚合函数

2.请编写一条 SELECT 语句,求出销售单价(‘sale_price‘ 列)合计值大于进货单价(‘purchase_price‘ 列) 合计值 1.5 倍的商品种类。执行结果如下所示。

在这里插入图片描述

答:

在这里插入图片描述

  1. 在这里插入图片描述

    答:

    在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mrs.King_UP

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值