窗口函数(sample database classicmodels _No.8 )

news2025/1/21 0:53:48

窗口函数(sample database classicmodels _No.8 )

准备工作,可以去下载 classicmodels 数据库具体如下
点击:classicmodels

也可以去 下面我的博客资源下载
https://download.csdn.net/download/tomxjc/88685970

文章目录

  • 窗口函数(sample database classicmodels _No.8 )
  • 什么是窗口函数?
  • 二、实例1
  • 二、实例2
  • 总结


什么是窗口函数?

开窗函数(Window Function)是一种在关系型数据库中执行计算的功能,它能够在查询结果集的子集(窗口)上执行聚合、排序和分析操作,而不会改变原始查询结果的行数。开窗函数通常与聚合函数(如SUM、AVG、COUNT等)结合使用,以便在给定的窗口中对数据进行分析。

开窗函数在SQL标准中得到广泛支持,并且在许多主流的关系型数据库管理系统(如PostgreSQL、MySQL、Oracle、SQL Server等)中都有实现。

开窗函数的语法通常如下:

<窗口函数>(<表达式>) OVER (PARTITION BY <分区键> ORDER BY <排序键> [窗口定义])

其中:

<窗口函数>:要执行的聚合或分析函数,例如SUM、AVG、ROW_NUMBER等。
<表达式>:要对其执行窗口函数的列或表达式。
PARTITION BY:用于将结果集分区的列或表达式。它将数据分成不同的组,在每个组内执行窗口函数。
ORDER BY:对分区中的行进行排序的列或表达式。
[窗口定义]:可选部分,用于定义窗口的边界。包括ROWS、RANGE等窗口类型。
通过使用开窗函数,可以执行一系列分析操作,如计算累积总和、计算移动平均值、计算排名等。这使得在查询结果中执行复杂的分析变得更加简单和高效。

二、实例1

select orderNumber ,
orderLineNumber ,
productCode ,
quantityOrdered*priceEach as sumcost,  
sum(quantityOrdered*priceEach) over (PARTITION BY orderNumber) as totalcost,
row_number() over (PARTITION BY orderNumber order by quantityOrdered*priceEach desc) as cost_order
,concat( round(quantityOrdered*priceEach/sum(quantityOrdered*priceEach) over (PARTITION BY orderNumber) * 100.00,2.0) ,'%') as 'rate%'
FROM    orderdetails join orders USING (orderNumber)
where year(orderDate) in ('2004') and status='Shipped'

知识点:

quantityOrdered*priceEach as sumcost
sum(quantityOrdered*priceEach) over (PARTITION BY orderNumber) as totalcost

quantityOrdered-订单数量
priceEach-订单单价
sumcost就是总价
sum(quantityOrderedpriceEach)就是 单价和数量汇总
PARTITION BY orderNumber 意思是根据 orderNumber 分组
sum(quantityOrdered
priceEach) over (PARTITION BY orderNumber) 这个意思就是根据 orderNumber 分组后汇总订单金额
row_number() 函数 是 其分区内的当前行数
在这里插入图片描述

二、实例2

select orderNumber ,quantityOrdered*priceEach as sumcost, 
PERCENT_RANK() over (PARTITION BY orderNumber order by quantityOrdered*priceEach desc),
CUME_DIST() over (PARTITION BY orderNumber order by quantityOrdered*priceEach desc)
FROM    orderdetails join orders USING (orderNumber)
where year(orderDate) in ('2004') and status='Shipped'

在这里插入图片描述
PERCENT_RANK() over (PARTITION BY orderNumber order by quantityOrdered*priceEach desc)
这个数根据百分比算 出,百分比排名值,并且可以看到第一行永远是 0,表中orderbumber =10217 有 7个子订单,
就是1/(7-1)=0.16666 平分6份,每一份是 0.16666

CUME_DIST() over (PARTITION BY orderNumber order by quantityOrdered*priceEach desc)
这个数根据累计分组后的累计值 ,并不是平分值,1/7=0.1428 然后在累计

总结

mysql 开窗函数可以去这个找到

在这里插入图片描述
窗口函数(Window Function)是一种在SQL中执行计算的特殊函数,它能够在查询结果的子集(窗口)上进行聚合、排序和分析操作,而不改变原始查询结果的行数。窗口函数通常与OVER子句一起使用,以定义要应用窗口函数的数据子集。

窗口函数提供了一种在结果集内执行各种聚合和分析操作的强大机制,而无需对查询进行分组。这意味着您可以在结果集中执行各种计算而无需对整个结果集进行聚合。

窗口函数通常用于以下场景之一:

  • 对分组数据执行聚合操作:与GROUP
    BY子句不同,窗口函数可以对整个结果集进行聚合,而不会减少结果行数。例如,您可以计算每个行的累积总和或平均值。
  • 执行排名和排序操作:您可以使用窗口函数对结果集中的行进行排序,并为每行分配排名或行号。这使得可以轻松地确定数据的顺序和排名。
  • 执行移动平均和累积计算:窗口函数允许您在结果集内执行移动平均、累积和其他类似的计算。这对于趋势分析和预测非常有用。
  • 执行分析函数:您可以使用窗口函数执行各种分析操作,如计算行与前一行之间的差异或百分比变化等。
  • SQL标准中定义了一系列窗口函数,常见的包括SUM、AVG、COUNT、ROW_NUMBER、RANK、DENSE_RANK等。这些函数可以与OVER子句一起使用,以指定窗口的范围和排序方式。

但用的最频繁的一般这4个
函数DENSE_RANK() ,RANK(),ROW_NUMBER(),LAG()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1529609.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Visual Studio 2013 - 调试模式下根据内存地址查看内存

Visual Studio 2013 - 调试模式下根据内存地址查看内存 1. 查看内存References 1. 查看内存 调试 -> 窗口 -> 内存 -> 内存1-4 References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

Git浅谈配置文件和免密登录

一、文章内容 简述git三种配置ssh免密登录以及遇见的问题git可忽略文件git remote 相关操作 二、Git三种配置 项目配置文件(局部)&#xff1a;项目路径/.git/config 文件 git config --local user.name name git config --local user.email 123qq.cc全局配置文(所有用户): …

docker入门(二)—— docker三大概念(镜像、容器、仓库)

docker 的三大必要概念 docker 的三大必要概念——镜像、容器、仓库 docker 架构图 镜像&#xff08;image&#xff09;&#xff1a;模版。&#xff08;web项目&#xff1a;1、环境 2、配置变量 3、上线项目 4、配置项目需要的静态文件&#xff09;打包成镜像 docker 镜像&a…

LeetCode 2312.卖木头块:动态规划(DP)

【LetMeFly】2312.卖木头块&#xff1a;动态规划(DP) 力扣题目链接&#xff1a;https://leetcode.cn/problems/selling-pieces-of-wood/ 给你两个整数 m 和 n &#xff0c;分别表示一块矩形木块的高和宽。同时给你一个二维整数数组 prices &#xff0c;其中 prices[i] [hi, …

DNF的概念和操作命令

yum是linux系统中基于rpm包管理的一种软件管理工具。 在dnf.conf文件中&#xff0c;我们可以配置某个网络服务器位软件源仓库。配置的方法&#xff0c;就是用vim编辑/etc/dnf/dnf.conf这个文件。

基于 RisingWave 和 Kafka 构建实时网络安全解决方案

实时威胁检测可实时监控和分析数据&#xff0c;并及时对潜在的安全威胁作出识别和响应。与依赖定期扫描或回顾性分析的安全措施不同&#xff0c;实时威胁检测系统可提供即时警报&#xff0c;并启动自动响应来降低风险&#xff0c;而不会出现高延迟。 实时威胁检测有许多不同的…

C语言案例02,请编程序将“China“译成密码,密码规律是:用原来的字母后面第4个字母代替原来的字母,变为Glmre,持续更新~

一.题目 /* 请编程序将“China”译成密码,密码规律是:用原来的字母后面第4个字母代替原来的字母。 例如,字母“A”后面第4个字母是“E”&#xff0c;用“E”代替“A”。因此,“China”应译为“Glmre”。 请编一程序,用赋初值的方法使cl,c2&#xff0c;c3,c4,c5 这5个变量的值分…

避坑指南!树莓派使用Adafruit_PCA9685驱动

一、硬件连线 二、软件配置 打开树莓派的IIC sudo raspi-config下载Adafruit_PCA9685 坑&#xff1a;如果直接使用命令安装会发现&#xff0c;报下面的错误。我们需要先安装conda&#xff0c;然后创建一个虚拟环境&#xff0c;创建完成后&#xff0c;激活环境。不要在自己创…

Python自动化测试UniTest框架介绍用法

UnitTest是Python自带的一个单元测试框架 作用&#xff1a; 批量执行用例提供丰富的断言知识可以生成报告 核心要素&#xff1a; TestCase 测试用例TestSuite 测试案件TestRunner 以文本的形式运行测试用例TestLoader 批量执行测试用例-搜索指定文件夹内指定字母开头的模块F…

2024/03/19(网络编程·day5)

一、思维导图 二、selec函数实现TCP并发服务器 #include<myhead.h>#define SER_PORT 8888 //服务器端口号 #define SER_IP "192.168.117.116" //服务器IP int main(int argc, const char *argv[]) {//1、创建一个套接字int sfd -1;sfd socket(AF_INET,SOC…

【Week Y2】使用自己的数据集训练YOLO-v5s

Y2-使用自己的数据集训练YOLO-v5s 零、遇到的问题汇总&#xff08;1&#xff09;遇到git的import error&#xff08;2&#xff09;Error&#xff1a;Dataset not found&#xff08;3&#xff09;Error&#xff1a;删除中文后&#xff0c;训练图片路径不存在 一、.xml文件里保存…

开发微信小程序被鹅厂背刺

最近在开发微信小程序&#xff0c;没来得及更文。等开发完成后&#xff0c;给大家写保姆帖系列。刚刚看到一张动图&#xff0c;忍不住分享给大家。属实反映了鹅厂风格了。

C# Onnx Yolov9 Detect 物体检测

目录 介绍 效果 项目 模型信息 代码 下载 C# Onnx Yolov9 Detect 物体检测 介绍 yolov9 github地址&#xff1a;https://github.com/WongKinYiu/yolov9 Implementation of paper - YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information …

【电路笔记】-达林顿晶体管

达林顿晶体管 文章目录 达林顿晶体管1、概述2、基本达林顿晶体管配置3、示例4、达林顿晶体管应用5、Sziklai 晶体管对6、ULN2003A 达林顿晶体管阵列7、总结两个双极晶体管的达林顿晶体管配置可针对给定基极电流提供更大的电流切换。 1、概述 达林顿晶体管以其发明者 Sidney Da…

洛谷_P5143 攀爬者_python写法

P5143 攀爬者 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 知识点&#xff1a; Python lambda&#xff08;匿名函数&#xff09; | 菜鸟教程 (runoob.com) import mathn int(input()) data [] for i in range(n):l list(map(int,input().split()))data.append(l)data.so…

服务器硬件基础知识和云服务器的选购技巧

概述 服务器硬件基础知识涵盖了构成服务器的关键硬件组件和技术&#xff0c;这些组件和技术对于服务器的性能、稳定性和可用性起着至关重要的作用。其中包括中央处理器&#xff08;CPU&#xff09;作为服务器的计算引擎&#xff0c;内存&#xff08;RAM&#xff09;用于数据临…

解决重装系统之后,开始菜单找不到Anaconda3相关图标

一、anaconda3安装后在开始菜单找不到&#xff0c;如下图所示 二、进入Anaconda3安装的位置 在安装位置按住shift键鼠标右键&#xff0c;打开poworshell&#xff0c;输入 start cmd最后的结果如图。

力扣1. 两数之和

思路&#xff1a;用一个map存放 已遍历过的元素和下标&#xff1b; 若当前元素是nums[i], 且该元素的另一半 target-nums[i] 在已遍历过的map里面&#xff0c;则返回两个元素的下标&#xff1b; class Solution {public int[] twoSum(int[] nums, int target) {int[] ans new…

母亲的奶牛(bfs)

农夫约翰有三个容量分别为 A , B , C A,B,C A,B,C 升的挤奶桶。 最开始桶 A A A 和桶 B B B 都是空的&#xff0c;而桶 C C C 里装满了牛奶。 有时&#xff0c;约翰会将牛奶从一个桶倒到另一个桶中&#xff0c;直到被倒入牛奶的桶满了或者倒出牛奶的桶空了为止。 这一过…

云计算新宠:探索Apache Doris的云原生策略

文章目录 Apache Doris 特性极简架构高效自运维高并发场景支持MPP 执行引擎明细与聚合模型的统一便捷数据接入 Apache Doris 极速 1.0 时代极速列式内存布局向量化的计算框架Cache 亲和度虚函数调用SIMD 指令集 稳定多源 关于 Apache Doris 开源社区基于云原生向量数据库Milvus…