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

窗口函数(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()

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Java八股文(RabbitMQ)

Java八股文のRabbitMQ RabbitMQ RabbitMQ RabbitMQ 是什么&#xff1f;它解决了哪些问题&#xff1f; RabbitMQ 是一个开源的消息代理中间件&#xff0c;用于在应用程序之间进行可靠的异步消息传递。 它解决了应用程序间解耦、消息传递、负载均衡、故障恢复等问题。 RabbitMQ …

鸿蒙开发学习:【appspawn应用孵化组件】

功能简介 应用孵化器&#xff0c;负责接受应用程序框架的命令孵化应用进程&#xff0c;设置其对应权限&#xff0c;并调用应用程序框架的入口。 基本概念 appspawn注册的服务名称为“appspawn”。appspawn 通过监听本地socket&#xff0c;接收来自客户端的请求消息。消息类型…

Linux-MDK can电机带导轨 C++封装

我使用的是MKS的52D can电机带导轨&#xff0c;现在我要根据电机说明书将运动指令封装&#xff0c;有一个限位开关&#xff0c; 闭合时高电平 滑块需要运动在限位开关左侧&#xff0c;所以限位归零的方向为顺时针 根据说明书&#xff0c;我要设置的命令应该是&#xff1a; ca…

JavaScript实现简单的表单验证

关键代码&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><s…

13|连接数据库:通过链和代理查询鲜花信息

新的数据库查询范式 提出问题&#xff1a;用户用自然语言提出一个问题&#xff0c;例如“去年的总销售额是多少&#xff1f;”。LLM 理解并转译&#xff1a;LLM 首先会解析这个问题&#xff0c;理解其背后的意图和所需的信息。接着&#xff0c;模型会根据解析的内容&#xff0c…

蓝桥杯---代分数

import java.util.Scanner;public class top4 {//全排列分数的那个题目//首先进行n个数的全排列//然后将这n个数字拆分为3个数字&#xff0c;即插入两个板子//然后判断等式是否成立&#xff08;判断条件就是在if里面去进行相关的判断是吗&#xff1f;&#xff1f;&#xff09;s…

一文搞懂机器学习

一、引言 在当今的数字时代&#xff0c;一个概念不断出现在科技前沿的讨论中 —— 机器学习。作为人工智能领域的一个重要分支&#xff0c;机器学习已经从理论研究走向实际应用&#xff0c;深刻地改变着我们的工作和生活方式。 机器学习的核心思想是让机器通过数据学习并做出…

【教学类-44-08】20240319 “(幼儿用)数字练习簿1.0”(A4版)

背景需求&#xff1a; 我一直想把 “&#xff08;幼儿用&#xff09;数字练习簿”的内容复刻出来——这里面的字体始终找不到&#xff0c;是一种已经做成图片的手写数字字体 素材准备&#xff1a; 1、买了一本&#xff08;幼儿用&#xff09;数字练习簿&#xff0c;把每一页扫…

蓝桥杯--基础(哈夫曼)

import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Scanner;public class BASIC28 {//哈夫曼书public static void main(String[] args) {Scanner Scannernew Scanner(System.in);int nScanner.nextInt();List<Integer&…

Visual Studio 2013 - 调试模式下查看监视窗口

Visual Studio 2013 - 调试模式下查看监视窗口 1. 监视窗口References 1. 监视窗口 Ctrl Alt W&#xff0c;1-4&#xff1a;监视窗口 (数字键不能使用小键盘) or 调试 -> 窗口 -> 监视 -> 监视 1-4 调试状态下使用&#xff1a; 在窗口中点击空白行&#xff0c;…

Java项目打包成Docker镜像

将项目打包成Docker镜像 将项目打包成Docker镜像的原因是可以在一台电脑的环境下模拟多台不同性能电脑响应高并发请求时候的表现。这里我们模拟半个CPU、一个CPU还有两个CPU的情况 在pom.xml文件中添加jib插件&#xff08;前提电脑安装了maven和Java 的 JDK才能成功完成编译&…

学习笔记 | 微信小程序项目day04

今日学习内容 热门推荐下转页面 热门推荐下转页面 1、定义类型 import type { PageResult, GoodsItem } from ./global/** 热门推荐 */ export type HotResult {/** id信息 */id: string/** 活动图片 */bannerPicture: string/** 活动标题 */title: string/** 子类选项 */…

STM32—控制蜂鸣器(定时器)

目录 1 、 电路构成及原理图 2 、编写实现代码 main.c tim_irq.c 3、代码讲解 4、烧录到开发板调试、验证代码 5、检验效果 此笔记基于朗峰 STM32F103 系列全集成开发板的记录。 1 、 电路构成及原理图 定时器中断是利用定时器的计数功能&#xff08;向上计数或向下计…

Java 多线程(抢CPU)

哈哈哈 什么是多线程&#xff1a;可以让程序同时做多件事情。 多线程的作用&#xff1a;提高效率。 多线程的应用场景&#xff1a;想让多个事情同时运行。 并发&#xff08;多个指令在单个CPU交替执行&#xff09;和并行&#xff08;多个指令在多个CPU交替执行&#xff09; …

《UE5_C++多人TPS完整教程》学习笔记28 ——《P29 Mixamo 动画(Mixamo Animations)》

本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P29 Mixamo动画&#xff08;Mixamo Animations&#xff09;》 的学习笔记&#xff0c;该系列教学视频为 Udemy 课程 《Unreal Engine 5 C Multiplayer Shooter》 的中文字幕翻译版&#xff0c;UP主&#xff08;也是译者…

MySQL数据自动同步到Es

Logstash 测试数据准备 DROP DATABASE IF EXISTS es;CREATE DATABASE es DEFAULT CHARACTER SET utf8;USE es;CREATE TABLE book (id INT NOT NULL,title VARCHAR(20),author VARCHAR(20),price DECIMAL(6,2),PRIMARY KEY(id) );DROP PROCEDURE IF EXISTS batchInsertBook;DELI…

飞桨AI应用@riscv OpenKylin

在riscv编译安装飞桨PaddlePaddle参见&#xff1a; 算能RISC-V通用云编译飞桨paddlepaddleopenKylin留档_在riscv下进行paddlelite源码编译-CSDN博客 安装好飞桨&#xff0c;就可以用飞桨进行推理了。刚开始计划用ONNX推理&#xff0c;但是在算能云没有装上&#xff0c;所以最…

第六篇:视频广告格式上传指南(上) - IAB视频广告标准《数字视频和有线电视广告格式指南》

第六篇&#xff1a; 视频广告格式和上传指南&#xff08;上&#xff09; --- 我为什么要翻译介绍美国人工智能科技公司IAB系列技术标准&#xff08;2&#xff09; 流媒体数字视频的广告格式分为线性和非线性两大类。任何一个广告都可以与显示在视频播放器外部的伴随横幅一起提…

教你读懂cert-manager官网并且使用letsencrypt(一)。

这一篇文章主要讲如果通过cert-manager letsencrypt的方式 自动管理你的证书。 一、怎么装&#xff1f; Installation - cert-manager Documentation 选个符合你环境的&#xff0c;推荐helm来管理你的应用。 二、怎么用&#xff1f; 官网说的&#xff1a; 意思就是你安装了…

Positive Technologies 专家发现的漏洞已在 ABB 控制器中得到修复

&#x1f31f; 我们的同事一如既往地表现出色&#xff1a;应用分析专家 Natalia Tlyapova 和 Denis Goryushev 因发现 Freelance AC 900F 和 AC 700F 控制器中的两个漏洞而受到 ABB 的表彰。 这些设备用于自动化大规模连续循环生产设施和构建企业配送控制系统。利用这些漏洞的…