SQL中开窗函数

昨天无意中听到这个函数(开窗函数),当时一脸懵逼。不知在阅读这篇文章的你,是否知道这个函数呢?

 

聚合函数是把多行合并为一行,

开窗函数是把一行分为多行。

无意中听到这个函数(开窗函数),当时一脸懵逼。不知在阅读这篇文章的你,是否知道这个函数呢?

开窗函数的调用格式为:函数名(列) OVER(选项)

注意:as关键字要在over()开窗函数后使用。

 

 

开窗函数被分为两大类如下:

扫描二维码关注公众号,回复: 3576746 查看本文章

第一大类:聚合开窗函数====》聚合函数(列) OVER (选项),这里的选项可以是PARTITION BY子句,但不可是ORDER BY子句

第二大类:排序开窗函数====》排序函数(列) OVER(选项),这里的选项可以是ORDER BY子句,也可以是 OVER(PARTITION BY子句 ORDER BY子句),但不可以是PARTITION BY子句

 

示例(使用第一类):

 

--不知道开窗函数时

SELECT  P_ID,COUNT(*) as 数量 FROM NewLiningDocument GROUP BY P_ID

--知道开窗函数后

SELECT DISTINCT  P_ID,COUNT(*) OVER(PARTITION BY P_ID) as 数量 FROM NewLiningDocument

猜你喜欢

转载自blog.csdn.net/MonkeyBananas/article/details/80183762
今日推荐