首页 > 数据库 >【SQL】SQL常见窗口函数整理汇总大全(用到over的场景)

【SQL】SQL常见窗口函数整理汇总大全(用到over的场景)

时间:2022-08-17 09:46:54浏览次数:86  
标签:窗口 函数 over SQL 排序 frame 大全

〇、概述

1、常用网站

SQL窗口函数:https://blog.csdn.net/liangmengbk/article/details/124253806

2、介绍

像聚合函数一样对一组数据进行分析并返回结果

3、与聚合函数的不同

聚合函数将一组数据汇总成单个结果,窗口函数为每一行数据都返回一个结果

一、窗口函数组成

(一)语法

窗口函数()  over(partition by xxx order by yyy  frame_clause)

frame_clause:框架子句,即窗口范围

(二)标识窗口-over

OVER子句用于指定一个数据分析的窗口,表明是一个窗口函数

括号内为空,表示将所有数据作为一个分组进行汇总

(三)分区-PARTITION BY

PARTITION BY用于定义分区,类似于查询语句中的GROUP BY子句

(四)排序-ORDER BY

ORDER BY用于指定分区内数据的排序方式,类似于查询语句中的ORDER BY子句

(五)指定窗口大小

frame_clause选项用于指定一个移动的分析窗口

窗口函数不再基于分区进行分析,而是基于窗口内的数据进行分析。

ROWS表示以数据行为单位计算窗口的偏移量,RANGE表示以数值(例如10天、5km等)为单位计算窗口的偏移量。

frame_start和frame_end分别定义窗口的起始位置和结束位置

窗口大小选项的定义:

如:

ROWS

  RANGE INTERVAL '5' DAY PRECEDING

  BETWEEN UNBOUNDED PRECEDING

  AND

   CURRENT ROW

二、窗口函数分类

(一)聚合窗口函数

常见的聚合函数可以做窗口函数,如AVG()、SUM()、COUNT()、MAX()以及MIN()等

(二)排序窗口函数

对数据进行分组排名,包括ROW_NUMBER()、RANK()、DENSE_RANK()、PERCENT_RANK()、CUME_DIST()以及NTILE()等函数。

使用窗口函数按照dt升序进行排序

row_number 排序结果是 1、2、3、4……

rank 排序结果是 1、2、2、4……

dense_rank 排序结果是 1、2、2、3…… 

(三)取值窗口函数

用于返回指定位置上的数据行,包括FIRST_VALUE()、LAST_VALUE()、LAG()、LEAD()、NTH_VALUE()等函数。

如:NTH_VALUE(use_time,2) OVER(PARTITION BY exam_id ORDER BY use_time ASC) AS min_use_time 

标签:窗口,函数,over,SQL,排序,frame,大全
From: https://www.cnblogs.com/liujinhui/p/16593838.html

相关文章

  • 2022-8-16 mysql 第二天 约束
    DQL数据库查询语言重点,DQL是我们每天都要接触编写最多也是最难的SQL,该语言用来查询记录,不会修改数据库和表结构。构建数据库创建一张student表:DROPTABLEIFEXISTSst......
  • 迁移与备份,Dockerfile,Docker私有仓库,Docker-compose,Mysql主从搭建,django读写分离
    1迁移与备份#一个容器内,尽量只有一个软件,不要把mysql,redis,。。。方到一个容器中,而要放到多个容器#镜像---》容器---》装了软件(vim,mysql)---》打包成镜像#打包后的镜......
  • MySQL篇:MySQL主从搭建、django读写分离
    目录一、MySQL主从搭建1.1什么是主从同步?1.2原理1.3搭建步骤1.3.1拉取mysql5.7镜像1.3.2创建一些文件夹,用来做目录映射1.3.3启动两个docker容器1.3.4链接主库1.3.5......
  • mysql术语通解
    数据库---文件夹表---文件字段---表头索引---目录约束---限制键---序号内连接---向右关联两张表的公共区外连接---向右关联两张表的公共区+独有区左外连接......
  • MySQL45讲-事务隔离和索引
    一、事务1.概述事务就是要保证一组数据库操作,要么全部成功,要么全部失败。在MySQL中,事务支持是在引擎层实现的。MyISAM引擎就不支持事务,InnoDB是支持事务。2.隔离......
  • MySQL45讲学习-基础构架查询和更新一条sql语句
    一、基础构架1.概述MySQL可以分为Server层和存储引擎层两部分,Server层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖MySQL的大多数核心服务功能,以及所......
  • MySQl二
    createtableemp(idintprimarykeyauto_increment,namevarchar(32),dep_idintunique,foreignkey(dep_id)referencesdep(id)onupdatecascadeondeletecascade)......
  • Mysql死锁解决办法
    使用navicat客户端工具连接上测试的mysql数据库,新建一个测试表CREATETABLE`t_user`( `id`int(11)NOTNULLAUTO_INCREMENTCOMMENT'用户编号', `login_name`......
  • mysql 慢了8小时的处理 mongo
    dockermysql时间差8个小时的解决方案1.临时改(重启就失效)  showvariableslike'%time_zone%';  2.解决方案,修改本地(验证过了)dockercp/usr/share/zonei......
  • MySQL之约束条件
    约束条件primarykeyprimarykey主键单从约束角度讲主键等价于非空且唯一notnullunique1.创建一个非空且唯一的表createtablep1(idintnotnullunique,namevar......