这PostgreSQL中提供了窗口函数,一个窗口函数在一系列与当前行有某种关联的表行上进行一种计算。下面这篇文章主要给大家介绍了关于PostgreSQL数据库中窗口函数的语法与使用的相关资料,需要的朋友可以参考下

什么是窗口函数?

一个窗口函数在一系列与当前行有某种关联的表行上执行一种计算。这与一个函数所完成的计算有可比之处。但是窗口函数并不会使多行被成一个单独的输出行,这与通常的非窗口函数不同。取而代之,行保留它们独立的标识。在这些现象背后,窗口函数可以访问的不仅仅是查询结果的当前行。

    可以访问与当前记录相关的多行记录; 不会使多行成一行, 与函数的区别;

窗口函数语法

窗口函数跟随一个 OVER 子句, OVER 子句决定究竟查询中的哪些行被分离出来由窗口函数处理。

可以包含分区 (PARTITION BY) 和排序 (ORDER BY) 指令, 这二者都是可选的。

window_func() OVER([PARTITION BY field] [ORDER BY field])

如果没有指定 PARTITION BY 和 ORDER BY 指令, 则等同于聚合函数, 对全部数据进行计算。

PARTITION BY 子句将查询的行分组成为分区, 窗口函数会独立地处理它们。PARTITION BY 工作起来类似于一个查询级别的 GROUP BY 子句, 不过它的表达式总是只是表达式并且不能是输出列的名称或编号。 如果没有 PARTITION BY, 该查询产生的所有行被当作一个单一分区来处理。

ORDER BY 子句决定被窗口函数处理的一个分区中的行的顺序。 它工作起来类似于一个查询级别的 ORDER BY 子句, 但是同样不能使用输出列的名称或编号。 如果没有 ORDER BY, 行将被以未指定的顺序被处理。

PostgreSQL 中的聚合函数也可以作为窗口函数来使用

除了这些内置的窗口函数外,任何内建的或用户定义的通用或统计(也就是有序集或假想集除外)都可以作为窗口函数。仅当调用跟着OVER子句时,函数才会作为窗口函数;否则它们作为非窗口的并为剩余的集合返回单行。

窗口函数示例

员工工资 (emp_salary) 表结构如下:

SELECT emp_no, dep_name, salary
FROM public.emp_salary
order by dep_name, emp_no;
emp_iddep_namesalary7develop42008develop60009develop450010develop520011develop52002personnel39005personnel35001sales50003sales48004sales4800

如果要将每位员工与其部门的平均工资进行对比, 需要这样的结果:

emp_iddep_namesalaryavg7develop420050208develop600050209develop4500502010develop5200502011develop520050202personnel390037005personnel350037001sales50004866.666666666673sales48004866.666666666674sales48004866.66666666667

如果不用窗口函数来查询, 则比较复杂, 当然也能做到, 语句如下:

SELECT e0.emp_no, e0.dep_name, e0.salary, e2.avg_salary
FROM public.emp_salary e0
join (
 select e1.dep_name, avg(e1.salary) as avg_salary
 from public.emp_salary e1
 group by e1.dep_name
) e2 on e2.dep_name = e0.dep_name
order by e0.dep_name, e0.emp_no;

如果使用窗口函数进行查询, 则很容易做到, sql 语句如下:

SELECT emp_no, dep_name, salary,
  avg(salary) over(partition by dep_name)
FROM public.emp_salary
order by dep_name, emp_no;

但是如果要查询随着员工的增加, 各部门平均工资的变化, 如下表所示的结果, 不用窗口函数查询的话就很难做到了。

emp_iddep_namesalaryavg7develop420042008develop600051009develop4500490010develop5200497511develop520050202personnel390039005personnel350037001sales500050003sales480049004sales48004866.66666666667

如果使用窗口函数, 依然可以轻松完成, 语句如下:

SELECT emp_no, dep_name, salary,
  avg(salary) over(partition by dep_name order by emp_no)
FROM public.emp_salary
order by dep_name, emp_no;

可见, 窗口函数在需要对查询结果中的相关行进行计算时有很大的优势。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对爱安网的支持。

最新资讯
中国移动董昕:建设5G的同时 确保4G网络服务不下降

中国移动董昕:建设5G的

在今日的2020世界5G大会主论坛上,中国移动总经理董昕发
魔点科技获1.2亿元C轮融资 同创伟业领投

魔点科技获1.2亿元C轮

人工智能企业魔点科技今日宣布已完成1.2亿元C轮融资。
科技部相里斌:未来两三年5G基础设施建设将进一步加快

科技部相里斌:未来两三

在大会开幕式上,科学技术部副部长相里斌在致辞时表示,预
网红第一股私有化:资本市场不相信颜值?

网红第一股私有化:资本

新一季财报刚发布两天,如涵再一次传来新动向,公司发布公
科技部副部长相里斌:以5G为代表的移动通信技术将不断加速发展

科技部副部长相里斌:以

在2020年世界5G大会开幕式上,科学技术部副部长相里斌表
因隐瞒企业信息真实情况 易果生鲜关联公司被列入经营异常名单

因隐瞒企业信息真实情

天眼查App显示,近日,上海易果食品零售有限公司被上海市
最新文章
PostgreSQL基础知识之SQL操作符实践指南

PostgreSQL基础知识之

这篇文章主要给大家介绍了关于PostgreSQL基础知识之SQ
pgsql查询优化之模糊查询实例详解

pgsql查询优化之模糊

这篇文章主要给大家介绍了关于pgsql查询优化之模糊查
Ubuntu PostgreSQL安装和配置的介绍

Ubuntu PostgreSQL安

今天小编就为大家分享一篇关于Ubuntu PostgreSQL安装
PostgreSQL实现一个通用标签系统

PostgreSQL实现一个通

这篇文章主要给大家介绍了关于利用PostgreSQL实现一个
PostgreSQL中使用数组改进性能实例代码

PostgreSQL中使用数组

这篇文章主要给大家介绍了关于PostgreSQL中使用数组改
Postgresql主从异步流复制方案的深入探究

Postgresql主从异步流

这篇文章主要给大家介绍了关于Postgresql主从异步流复