zoukankan      html  css  js  c++  java
  • 第八章 SQL高级处理 8-1 窗口函数

    一、什么是窗口函数
    窗口函数也称为LOAP函数。OnLine Analytical Processing的简称。意思是对数据库数据进行实时分析处理。
    窗口函数就是为实现OLAP而添加的标准SQL功能。
    注:截止2016年5月,Oracle/SQL Server/DB2/PostgreSQL的最新版本都已经支持该功能,但目前MySQL5.7还不支持窗口函数。
     
    二、窗口函数的语法
    1、能够作为窗口函数使用的函数
    (1)能够作为窗口函数的聚合函数(SUM/AVG/COUNT/MAX/MIN)
    (2)RANK/DENSE_RANK/ROW_NUMBER等专用窗口函数。
     
    二、语法的基本使用方法——使用RANK函数
    PARTITION BY能够设定排序的对象范围。
    ORDER BY能够指定按照哪一列,何种顺序进行排序。
    RANK函数并不会减少原表找那个记录的行数。
     
    三、无需指定PARTITION BY
     
    四、专用窗口函数的种类
    注:由于专用窗口函数无需参数,因此通常括号中都是空的。
     
    五、窗口函数的使用范围
    原则上窗口函数只能在SELECT子句中使用。
     
    六、作为窗口函数使用的聚合函数
    像这样以“自身记录(当前记录)”作为基准进行统计,就是将聚合函数当做窗口函数使用的最大特征。
     
    七、计算移动平均
    窗口函数就是将表以窗口为单位进行分割,并在其中进行排序的函数。其实其中还包含在窗口中指定更加详细的汇总范围的备选功能,该备选功能中的汇总范围称为框架。
    1、指定框架(汇总范围)
    由于框架是根据当前记录来确定的,因此和固定的窗口不同,其范围会随着当前记录的变化而变化。
    ROW PRECEDING 截止到之前~行
    ROW FOLLOWING 截止到之后~行
     
    2、将当前记录的前后行作为汇总对象
     
    八、两个ORDER BY
    OVER子句中的ORDER BY只是用来决定窗口函数按照什么样的顺序进行计算的,对结果的排列顺序并没有影响。
    注:使用汇总函数作为窗口函数使用时,会以当前记录为基准来决定汇总对象的记录。
     
     

  • 相关阅读:
    C++11学习笔记
    孙鑫MFC学习笔记20:Hook编程
    孙鑫MFC学习笔记19:动态链接库
    孙鑫MFC学习笔记18:ActiveX
    孙鑫MFC学习笔记17:进程间通信
    孙鑫MFC学习笔记16:异步套接字
    孙鑫MFC学习笔记:15多线程
    ionic2 使用slides制作滑动效果的类型选择栏
    JavaScript简明教程之Node.js
    ionic2实战-使用Chart.js
  • 原文地址:https://www.cnblogs.com/mumulin99/p/9837432.html
Copyright © 2011-2022 走看看