Oracle-分析函数(累计求和,排序等)
在Oracle中分析函数又称为开窗函数
分为以下两类:
第一类:是聚合分析函数,主要包含(sum,count,AVG、MAX、MIN等),主要是对内部分组的数值按照要求内部聚合处理;
第二类:是排序分析函数,主要包含(ROW_NUMBER、DENSE_RANK、RANK等),根据不同要求呈现不同的排序方式。
结构函数介绍:
SELECT table.column,
analysis_function() OVER ( [PARTITION BY 字符] [ORDER BY 字段 [rows]] ) as 统计值FROM table;
analysis_function表示分析函数,对应的有sum,count,AVG、MAX、MIN,ROW_NUMBER、DENSE_RANK、RANK等;
OVER:开窗函数名;
partition by :为分组字段;
order by :指定排序字段;
rows:指定数据窗口(即指定分析函数要操作的行数)
聚合分析函数
一、聚合分析函数与聚合函数的不同
聚合分析函数可以在查询语句中,每一组每一行进行聚合,聚合函数只能通过group by 整体聚合。
二、聚合分析函数
聚合分析函数:()中需要填值
--组内计数
count() over(partition by ... order by ...)
--组内最大值
max() over(partition by ... order by ...)
--组内最小值
min() over(partition by ... order by ...)
--组内求和,可计算累计求和
sum() over(partition by ... order by ...)
--组内均值
avg() over(partition by ... order by ...)
--组内的第一个值
first_value() over(partition by ... order by ...)
--组内的最后一个值
last_value() over(partition by ... order by ...)
--Lag函数可以在一次查询中取出当前行的同一字段的前面第N行的数据。
lag() over(partition by ... order by ...)
--Lead函数可以在一次查询中取出当前行的同一字段的后面第N行的值。
lead() over(partition by ... order by ...)
举例:
sum() over(partition by … order by …) 累计求和
select 营销中心,事业部,产品编码,产品名称,品类,年份,月份,月,当月指标金额,sum(当月指标金额) over(partition by 营销中心, 事业部,产品编码,产品名称,品类,年份
ORDER BY 月
) 月累计指标,
sum(当月指标金额) over(partition by 营销中心,事业部,产品编码,年份
ORDER BY 产品编码
) 全年指标
FROM TABLE;
排序分析函数
分为 rank,dense_rank,row_number 三种排序方式。
对应的函数结构如下所示:
rank ( ) over ( [query_partition_clause]order_by_clause )
--rank如果出现两个相同的数据,那么后面的数据就会直接跳过这个排名,比如:当第2名和第3名的利润相同时,rank的结果是1,2,2,4;select d,l,m,rank() over(partition by d order by l) from aaa;
dense_rank ( ) over ([query_partition_clause] order_by_clause )
--dense_rank则不会跳过这个排名,结果是1,2,2,3
select d,l,m,dense_rank() over(partition by d order by l) from aaa;
row_number ( ) over ( [query_partition_clause]order_by_clause )
--row_number哪怕是两个数据完全相同,排名也会不一样,结果是1,2,3,4
select d,l,m,row_number() over(partition by d order by l) from aaa;
通过上面的结构可实现按指定的字段分组排序,对于相同分组字段的结果集进行排序
排序分析函数:()中不填值
--重复排序(1,2,3,4)
row_number() over(partition by ... order by ...)
--重复跳过排序(1,2,2,4)
rank() over(partition by ... order by ...)
--重复不跳过排序(1,2,2,3)
dense_rank() over(partition by ... order by ...)相关文章:
Oracle-分析函数(累计求和,排序等)
在Oracle中分析函数又称为开窗函数 分为以下两类: 第一类:是聚合分析函数,主要包含(sum,count,AVG、MAX、MIN等),主要是对内部分组的数值按照要求内部聚合处理; 第二类&a…...
4本期刊被踢!11月SCI/SSCI目录已更新
2023年11月20日,科睿唯安更新了Web of Science核心期刊目录。 此次更新后SCIE期刊目录共包含9481本期刊,SSCI期刊目录共包含3551本期刊。此次SCIE & SSCI期刊目录更新,与上次更新(2023年10月)相比,共…...
JS中Cookie的基本使用
JavaScript 创建Cookie: JavaScript 读取 Cookie : JavaScript 修改 Cookie: JavaScript 删除 Cookie : JavaScript Cookie(JavaScript 的 Cookie)是一种在Web浏览器中存储和检索用户信息的机制。它允许…...
关闭windows防火墙命令
关闭windows防火墙命令 打开windows PowerShell (管理员) 或 CMD (管理员) 指令: 查看当前防火墙状态:netsh advfirewall show allprofiles 关闭防火墙:netsh advfirewall set allprofiles state off 开启防火墙:netsh advfirewa…...
excel-gen.js 导出excel 功能
目录 概要 整体架构流程 html部分: js部分: json部分: 小结 概要 功能会使用到如下插件: jszip.min.js FileSaver.js jquery.min.js excel-gen.js highcharts.js exporting.js export_data.js 主要是highcharts图表…...
键鼠自动化2.0展示
软件介绍:桌面键鼠自动化工具 Qtc 编写: 本软件采用Qt C编写,旨在提供高效、跨平台的桌面键鼠自动化解决方案。Qt C框架的选择确保了软件的稳定性、可靠性,并通过其图形用户界面实现了用户友好的操作体验。 鼠标移动与点击&#…...
html主页框架,前端首页通用架构,layui主页架构框架,首页框架模板
html主页框架 前言功能说明效果使用初始化配置菜单加载主题修改回调 其他非iframe页面内容使用方式iframe页面内容使用方式 前言 这是一个基于layui、jquery实现的html主页架构 平时写的系统后台可以直接套用此框架 由本人整合编写实现,简单上手,完全免…...
SDWAN厂家排名
随着网络技术的不断发展,SDWAN(软件定义广域网)作为一种新兴的网络架构,正在受到越来 越多企业的关注和采用。选择一家可靠的SDWAN厂家成为企业成功部署和管理SDWAN的关键。本文将从技术实力、客户口碑以及市场占有率三个方面&…...
【STM32】CRC(循环冗余校验)
一、CRC的背景知识 1、什么是CRC (1)CRC(Cyclic Redundancy Check),循环冗余校验 (2)什么是校验,为什么需要校验:数据传输,数据存储过程中需要使用到的 (3)什么是冗余:表示比实际上要传输的数据…...
04.webpack中css的压缩和抽离
1.抽离css文件 利用mini-css-extract-plugin插件,替代style-loader const MiniCssExtractPlugin require(mini-css-extract-plugin) module.exports smart(webpackCommonConf, {mode: production,output: {// filename: bundle.[contentHash:8].js, // 打包代码…...
Vue 3 和 Spring Boot 3 的操作流程和执行步骤详解
1.介绍 在本篇博客中,我们将详细介绍Vue 3 和 Spring Boot 3 的操作流程和执行步骤。Vue 3 是一款流行的前端框架,而Spring Boot 3 是一款广泛应用于后端开发的框架。通过结合使用这两个框架,我们可以构建出功能强大的全栈应用。 2.Vue 3 的操…...
获取所有非manager的员工emp_no
个人网站 文章首发于公众号小肖学数据分析 题目来自牛客网 描述 有一个员工表employees简况如下: emp_nobirth_datefirst_namelast_namegenderhire_date100011953-09-02GeorgiFacelloM1986-06-26100021964-06-02BezalelSimmelF1985-11-21100031959-12-03PartoBamfordM1986…...
STM32存储左右互搏 SPI总线FATS文件读写FLASH W25QXX
STM32存储左右互搏 SPI总线FATS文件读写FLASH W25QXX FLASH是常用的一种非易失存储单元,W25QXX系列Flash有不同容量的型号,如W25Q64的容量为64Mbit,也就是8MByte。这里介绍STM32CUBEIDE开发平台HAL库实现FATS文件操作W25Q各型号FLASH的例程。…...
Sentinel 熔断规则 (DegradeRule)
Sentinel 是面向分布式、多语言异构化服务架构的流量治理组件,主要以流量为切入点,从流量路由、流量控制、流量整形、熔断降级、系统自适应过载保护、热点流量防护等多个维度来帮助开发者保障微服务的稳定性。 SpringbootDubboNacos 集成 Sentinel&…...
嵌入式Linux开发面试题和答案
熟练的编程语言: 问:“您在嵌入式系统开发中熟练使用哪些编程语言?”答:在嵌入式系统开发中,我熟练使用C、C和Python等编程语言。C语言因其接近硬件的操作和效率而被广泛应用;C则在需要面向对象编程时提供了…...
Linux安装Mysql详细教程(两种安装方法)
Linux之Mysql安装配置 第一种:Linux离线安装Mysql(提前手动下载好tar.gz包)第二种:通过yum安装配置Mysql(服务器有网络) 第一种:tar.gz包安装 1、 查看是否已经安装 Mysql rpm -qa | grep m…...
用向量数据库Milvus Cloud搭建GPT大模型+私有知识库的定制商业文案助手
随着智能助手的不断普及和发展,商业文案的创作也变得更加智能化和定制化。在这个信息爆炸的时代,商业文案的撰写已经不再是简单的文字表达,而是需要结合大数据分析和人工智能技术,以更好地满足目标客群的需求。在本文中,我们将介绍如何利用向量数据库Milvus Cloud搭建GPT大…...
redis---非关系型数据库
关系数据库与非关系型数据库 redis非关系型数据库,又名缓存型数据库。数据库类型:关系型数据库和非关系型数据库关系型数据库是一 个机构化的数据库,行和列。 列:声明对象。 行:记录对象属性。 表与表之间的的关联。 sql语句&…...
Java WebSocket 获取客户端 IP 地址
在开发 Web 应用程序时,我们通常需要获取客户端的 IP 地址用于日志记录、身份验证、限制访问等操作。当使用 WebSocket 协议时,我们可以使用 Java WebSocket API 来获取客户端的 IP 地址。 本文将介绍如何使用 Java WebSocket API 获取客户端 IP 地址&a…...
【HarmonyOS】低代码平台组件拖拽使用技巧之页签容器
【关键字】 HarmonyOS、低代码平台、Tabs、TabContent、页签导航 1、写在前面 前面几篇分别介绍了低代码平台中的堆叠容器、滚动容器、网格布局等三种容器的使用,实际开发中我们经常会有这样的需求,页面底部是三个Tab按钮点击时会分别切换不同的视图内…...
SkillMana:AI编程技能本地化管理利器,符号链接与智能路由解析
1. 项目概述:SkillMana,一个为AI编程伙伴管理“技能包”的本地利器 如果你和我一样,深度使用Cursor这类AI编程工具,那你一定遇到过这个甜蜜的烦恼:官方和社区提供的“技能”(Skills)越来越多&a…...
ChatGPT-RetrievalQA数据集解析:用合成数据训练检索模型的实践指南
1. 项目概述与核心问题最近在信息检索和自然语言处理社区里,一个话题讨论得挺热:既然像ChatGPT这样的大语言模型已经能生成相当不错的答案,我们为什么还需要传统的检索模型?更进一步,ChatGPT生成的这些答案,…...
AI模型公平性挑战与缓解策略:从数据偏见到算法公正
1. 项目概述:当AI开始“看人下菜碟” 最近几年,AI模型在各个领域大放异彩,从筛选简历到审批贷款,从医疗诊断到司法量刑辅助,其决策的影响力日益深远。然而,一个幽灵正在AI的世界里徘徊——不公平的幽灵。你…...
Taotoken模型广场如何帮助开发者根据任务需求快速选择合适的模型
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Taotoken模型广场如何帮助开发者根据任务需求快速选择合适的模型 面对市场上众多的大模型,开发者常常陷入选择困境&…...
GPTree GUI:本地化、可视化代码库预处理工具,精准提交LLM
1. 项目概述:一个为LLM准备代码库的本地桌面工具如果你和我一样,经常需要把项目代码喂给ChatGPT、Claude或者本地部署的Llama来寻求帮助,那你肯定遇到过这个麻烦:怎么把代码“打包”给AI看?直接复制粘贴?文…...
开源AI智能体中心:统一管理Claude、Cursor等工具的提示词与工作流
1. 项目概述:一个跨平台、跨部门的AI智能体中心如果你和我一样,每天都在和Claude Code、Cursor、ChatGPT、Gemini这些AI工具打交道,那你肯定也遇到过这个痛点:每次开始一个新项目,或者切换一个工作角色,都得…...
Kuramoto模型与CNN融合:构建可解释的脑电信号特征提取与分类框架
1. 项目概述:从脑电信号到智能解码的桥梁脑电信号,这个记录大脑神经元集群电活动的微弱生物电信号,一直是神经科学、临床医学和脑机接口领域研究的核心。它蕴含着海量的信息,从简单的警觉状态到复杂的认知意图,但如何从…...
手把手教你拿下AI智能体行业8大含金量证书,轻松抢占行业高地!
文章介绍了如何进入AI智能体行业,强调了证书的重要性。作者建议读者尽早获取八大含金量高的证书,这些证书门槛友好、企业认可度高,且无需高深技术背景。文章指出,虽然智能体行业兴起不久,竞争不激烈,但行业…...
图片元数据修改软件
链接:https://pan.quark.cn/s/501400393eba找了半天没找到比较合适的图片元数据修改软件,用AI搓了一个,用着还行,分享出来给有需要的人,之前发原创给删除了可以检测一些常见AI图的原始数据并给出提示...
基于Docker容器化部署Atlassian Jira的完整实践指南
1. 项目概述与核心价值最近在帮一个中型研发团队做内部流程工具链的整合,核心需求是搭建一套稳定、可控且易于维护的协作与项目管理平台。在众多方案中,基于容器化部署的 Atlassian Jira 成为了我们的首选。而cptactionhank/docker-atlassian-jira这个 D…...
