SQL必学必会之窗口函数


prtyaa
prtyaa 2024-01-07 21:33:38 53170 赞同 0 反对 0
分类: 资源 标签: 运维
在SQL中,窗口函数是一种强大的工具,用于在查询结果中执行聚合、排序和分组操作,而不影响原始表的行数。这篇文章将介绍窗口函数的基本概念以及如何使用它们来解决各种数据分析和报告需求。

1.窗口函数基础

窗口函数的基本语法如下:

 over (partition by  order by )

其中,partition by用于对表进行分组,而不会减少原表的行数。例如,按班级分组可以使用 partition by 班级。

order by则用于对分组后的结果进行排序,可以选择升序(asc)或降序(desc)。例如,order by 成绩 desc 表示按成绩降序排列。

窗口函数的优势在于它们能够同时实现分组和排序的功能,而不像 group by 子句那样减少表的行数。这意味着你可以在不失去原始数据的情况下执行聚合和排名操作。

2.窗口函数示例

示例:统计每个班级的人数

让我们看一个示例,假设我们要统计每个班级的学生人数。使用窗口函数,我们可以轻松实现这一目标:

SELECT *,
       COUNT(*) OVER (PARTITION BY 班级) AS 班级人数
FROM 学生表

在这个示例中,COUNT(*) 函数作为窗口函数,使用 PARTITION BY 班级 实现了按班级分组并计算每个班级的学生人数,同时原始表的行数依旧不变,而每行数据则增加了一列新列`班级人数`。

3.窗口函数的三种排序方式

窗口函数有多种类型,包括 rank()、dense_rank() 和 row_number()。它们在处理并列名次时的行为不同:

rank()

函数会占用下一名次的位置,如果有并列名次的行。例如,如果前3名是并列的名次,结果将是 1,1,1,4。

dense_rank()

函数不会占用下一名次的位置,如果有并列名次的行。例如,前3名是并列的名次,结果是 1,1,1,2。

row_number()

函数不考虑并列名次,排名是正常的。例如,前3名是并列的名次,排名是正常的 1,2,3,4。

窗口函数还可以与聚合函数一起使用,以在结果中执行聚合操作,如总和、平均、计数、最大和最小值。以下是示例:

SELECT *,
       SUM(成绩) OVER (ORDER BY 学号) AS 当前总分,
       AVG(成绩) OVER (ORDER BY 学号) AS 当前平均分,
       COUNT(成绩) OVER (ORDER BY 学号) AS 当前人数,
       MAX(成绩) OVER (ORDER BY 学号) AS 最高分,
       MIN(成绩) OVER (ORDER BY 学号) AS 最低分
FROM 班级表

在此示例中,我们使用窗口函数将聚合函数应用于成绩,并按学号排序,以计算每个学生的当前总分、平均分、人数、最高分和最低分。

4.结论

窗口函数是 SQL 查询中强大的工具,它们允许我们在不减少原始数据行数的情况下执行分组、排序和聚合操作。通过了解窗口函数的基本语法和应用,您可以更灵活地分析数据和生成报告。无论是数据分析师还是数据库开发人员,掌握窗口函数都是一个有用的技能,可以大大简化复杂查询的编写和理解。

如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!

评价 0 条
prtyaaL2
粉丝 1 资源 1949 + 关注 私信
最近热门资源
银河麒麟桌面操作系统备份用户数据  130
统信桌面专业版【全盘安装UOS系统】介绍  128
银河麒麟桌面操作系统安装佳能打印机驱动方法  120
银河麒麟桌面操作系统 V10-SP1用户密码修改  108
麒麟系统连接打印机常见问题及解决方法  27
最近下载排行榜
银河麒麟桌面操作系统备份用户数据 0
统信桌面专业版【全盘安装UOS系统】介绍 0
银河麒麟桌面操作系统安装佳能打印机驱动方法 0
银河麒麟桌面操作系统 V10-SP1用户密码修改 0
麒麟系统连接打印机常见问题及解决方法 0
作者收入月榜
1

prtyaa 收益393.62元

2

zlj141319 收益218元

3

1843880570 收益214.2元

4

IT-feng 收益210.13元

5

风晓 收益208.24元

6

777 收益172.71元

7

Fhawking 收益106.6元

8

信创来了 收益105.84元

9

克里斯蒂亚诺诺 收益91.08元

10

技术-小陈 收益79.5元

请使用微信扫码

加入交流群

请使用微信扫一扫!