码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MYSQL窗口函数(Rows & Range)——滑动窗口函数用法


    语法介绍

    窗口函数语法:

    <窗口函数> over (partition by <用于分组的列名>
    order by <用于排序的列名>
    rows/range子句<用于定义窗口大小> )

    <窗口函数>可以放以下两种函数:
    1) 专用窗口函数,包括后面要讲到的rank, dense_rank, row_number等专用窗口函数。
    2) 聚合函数,如sum. avg, count, max, min等

    1)专用窗口函数

    rank, dense_rank, row_number这三个函数的区别在这篇文章里有详细介绍,简略说就是:

    • Rank:有相同名次,名次按实际个数走,会跳数字。
    • Dense_rank: 有相同名次,名次不跳数
    • Row_number:相同分数按行数排序
    分数RankDense_RankRow_number
    100111
    100112
    90323

    2)聚合函数

    这里以sum()为例子,使用常用的部门员工数据集,介绍聚合函数的不同组合用法

    例1: 求各个部门的薪酬总数:

    在这里插入图片描述

    3) 滑动窗口:rows&range用法

    [<ROWS or RANGE clause> BETWEEN <Start expr> AND <End expr>]
    
    • 1
    • ROWS: 表示按照行的范围进行定义框架,根据order by子句排序后,取的前N行及后N行的数据计算(与当前行的值无关,只与排序后的行号相关)。常用:rows n perceding表示从当前行到前n行(一共n+1行)
    • RANGE:表示按照值的范围进行定义框架,根据order by子句排序后,指定当前行对应值的范围取值,行数不固定,只要行值在范围内,对应行都包含在内。适用于对日期、时间、数值排序分组
    边界可取值(Start expr & End expr)说明
    Current Row当前行
    N preceding前 n 行,n 为数字, 比如 2 Preceding 表示前2行
    unbounded preceding开头
    N following后N行,n 为数字, 比如 2 following 表示后2行
    unbounded following结尾
    range取特定日期区间说明
    range interval 7-1 day preceding最近7天的值
    range between interval 1 day preceding and interval 1 day following前后一天和当天的值

    列2:求按id号累计员工的薪资(rows 用法)

    在这里插入图片描述
    注:如果将这里的rows 换成range 结果是一样的,因为这里使用id号排序,id和行号一致。


    例3:求每个员工的薪资情况以及对应±1万元及±5千元薪资范围内的人数 (Range用法)

    在这里插入图片描述
    Range 是根据值来组合排序的,结果中的第一行 Same的工资是60000, 而薪资范围内在50000-70000的人一共有4个,薪资范围内在55000-65000的人只有一个。


    参考问题连接

    累计问题: 牛客网 SQL159 每个创作者每月的涨粉率及截止当前的总粉丝量
    限制条件下的累计问题: 牛客网SQL160 国庆期间每类视频点赞量和转发量
    The RANGE Clause in SQL Window Functions: 5 Practical Examples

  • 相关阅读:
    搭建MyBatis以及Mybaits的相关配置与功能
    在伦敦银投资中,技术是万能的?
    背包问题汇总
    民安智库(北京第三方窗口测评)开展汽车消费者焦点小组座谈会调查
    【微机原理笔记】第 6 章 - 输入输出和中断技术
    2024智慧养老展,北京老博会,北京远程医疗展,适老科技展
    Ubuntu QtCreator不能输入中文,可以从其他位置复制中文
    【目录】人工智能与自动驾驶技术(入门整理)
    深度学习发展下的“摩尔困境”,人工智能又将如何破局?
    财长耶伦和她诺奖丈夫的千万身家
  • 原文地址:https://blog.csdn.net/WHYbeHERE/article/details/127896098
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号