网站首页 > 技术文章 正文
今天是元宵节,在此祝大家元宵快乐,梦想还在路上,让我们继续加油!
今天小编就为大家分享一篇关于Oracle连续相同数据的统计,先来复习一下之前用到的连续相同数据的统计。
首先,创建一个简单的测试表,这里过程就略过了。
第一种写法row_number():
SELECT val,COUNT(*) FROM (SELECT ID,val, row_number() OVER(ORDER BY ID)-row_number() OVER(PARTITION BY val ORDER BY ID) x FROM LCY ) GROUP BY val,x ORDER BY MIN(ID);
第二种rank():
SELECT val,COUNT(*) FROM (SELECT ID,val, rank() OVER(ORDER BY ID)-rank() OVER(PARTITION BY val ORDER BY ID) x FROM LCY) GROUP BY val,x ORDER BY MIN(ID);
第三种dense_rank():
SELECT val,COUNT(*) FROM (SELECT ID,val, dense_rank() OVER(ORDER BY ID)-dense_rank() OVER(PARTITION BY val ORDER BY ID) x FROM LCY )GROUP BY val,x ORDER BY MIN(ID);
结果:
三者在这里的用法只是换汤不换药,但是在其他的需求里还是有区别的,比如成绩排名。
本章涉及到的知识点是分析函数、聚合函数,除此之外还有数据分析函数和统计求和函数。
聚合函数
- SUM :该函数计算组中表达式的累积和
- MIN :在一个组中的数据窗口中查找表达式的最小值
- MAX :在一个组中的数据窗口中查找表达式的最大值
- AVG :用于计算一个组和数据窗口内表达式的平均值。
- COUNT :对一组内发生的事情进行累积计数
分析函数
- RANK :根据ORDER BY子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置
- DENSE_RANK :根据ORDER BY子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置
- FIRST :从DENSE_RANK返回的集合中取出排在最前面的一个值的行
- LAST :从DENSE_RANK返回的集合中取出排在最后面的一个值的行
- FIRST_VALUE :返回组中数据窗口的第一个值
- LAST_VALUE :返回组中数据窗口的最后一个值。
- LAG :可以访问结果集中的其它行而不用进行自连接
- LEAD :LEAD与LAG相反,LEAD可以访问组中当前行之后的行
- ROW_NUMBER:返回有序组中一行的偏移量,从而可用于按特定标准排序的行号
数据分析函数
- STDDEV :计算当前行关于组的标准偏离
- STDDEV_POP:该函数计算总体标准偏离,并返回总体变量的平方根
- STDDEV_SAMP:该函数计算累积样本标准偏离,并返回总体变量的平方根
- VAR_POP :该函数返回非空集合的总体变量(忽略null)
- VAR_SAMP :该函数返回非空集合的样本变量(忽略null)
- VARIANCE :如果表达式中行数为1,则返回0,如果表达式中行数大于1,则返回VAR_SAMP
- COVAR_POP :返回一对表达式的总体协方差
- COVAR_SAMP:返回一对表达式的样本协方差
- CORR :返回一对表达式的相关系数
- CUME_DIST :计算一行在组中的相对位置
- NTILE :将一个组分为"表达式"的散列表示
- PERCENT_RANK:和CUME_DIST(累积分配)函数类似
- PERCENTILE_DISC:返回一个与输入的分布百分比值相对应的数据值
- PERCENTILE_CONT:返回一个与输入的分布百分比值相对应的数据值
- RATIO_TO_REPORT:该函数计算expression/(sum(expression))的值,它给出相对于总数的百分比
- REGR_ (Linear Regression) Functions:这些线性回归函数适合最小二乘法回归线,有9个不同的回归函数可使用
统计求和函数
CUBE :按照OLAP的CUBE方式进行数据统计,即各个维度均需统计
后面小编会分享更多运维方面的干货,感兴趣的朋友走一波关注哩~
- 上一篇: 数据迁移的套路 数据迁移的四种方法
- 下一篇: oracle数据库学习笔记6-统计函数及分组查询
猜你喜欢
- 2024-11-05 超实用!手把手入门 MongoDB:这些坑点请一定远离
- 2024-11-05 T-SQL语句基础-增删改查 sql的增删改查指什么
- 2024-11-05 「计算机组成原理」:一文快速了解计算机原理知识点-附思维导图
- 2024-11-05 大数据分析师工程师入门6-HIVE进阶
- 2024-11-05 性能优化技巧:有序归并 有序表的归并算法
- 2024-11-05 java juc forkjoin 并行流计算详解
- 2024-11-05 《从实践中学习oracle/SQL》读书笔记 3
- 2024-11-05 MySQL常用函数详解,内含示例 mysql常用函数详解,内含示例分析
- 2024-11-05 word中最实用的办公技巧——神奇的F4,让你省时省力,效率翻倍
- 2024-11-05 mysql分组查询详解(group by & having)
你 发表评论:
欢迎- 621℃几个Oracle空值处理函数 oracle处理null值的函数
- 613℃Oracle分析函数之Lag和Lead()使用
- 602℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 598℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 594℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 586℃【数据统计分析】详解Oracle分组函数之CUBE
- 575℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 563℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)