PostgreSQL Oracle 兼容性之 - RATIO_TO_REPORT 分析函数

简介:

标签

PostgreSQL , Oracle , RATIO_TO_REPORT , 分析函数


背景

Oracle的分析函数RATIO_TO_REPORT()是用于计算当前值在分组内的占比的

RATIO_TO_REPORT is an analytic function. It computes the ratio of a value to the sum of a set of values.   

If expr evaluates to null, then the ratio-to-report value also evaluates to null.  

PostgreSQL也支持窗口查询,但是没有提供这个分析函数,不过我们知道它是干什么的,当然就知道如何写SQL来实现同样的目的了。

Oracle 例子

SELECT last_name, salary, RATIO_TO_REPORT(salary) OVER () AS rr  
   FROM employees  
   WHERE job_id = 'PU_CLERK';  

LAST_NAME                     SALARY         RR  
------------------------- ---------- ----------  
Khoo                            3100 .223021583  
Baida                           2900 .208633094  
Tobias                          2800 .201438849  
Himuro                          2600  .18705036  
Colmenares                      2500 .179856115  

PostgreSQL 例子

SELECT ID, val, 1.0 * val / NULLIF(SUM(val) OVER(),0) AS ratio_to_report  
FROM tab  

╔═════╦══════╦═════════════════════╗  
║ id  ║ val  ║   ratio_to_report   ║  
╠═════╬══════╬═════════════════════╣  
║  1  ║  10  ║ 0.16666666666666666 ║  
║  2  ║  10  ║ 0.16666666666666666 ║  
║  3  ║  20  ║ 0.3333333333333333  ║  
║  4  ║  20  ║ 0.3333333333333333  ║  
╚═════╩══════╩═════════════════════╝  
SELECT ID, val, category,  
    1.0 * val / NULLIF(SUM(val) OVER(PARTITION BY category),0) AS ratio_to_report  
FROM tab  

╔═════╦══════╦═══════════╦═════════════════╗  
║ id  ║ val  ║ category  ║ ratio_to_report ║  
╠═════╬══════╬═══════════╬═════════════════╣  
║  1  ║  10  ║ a         ║ 0.25            ║  
║  2  ║  10  ║ a         ║ 0.25            ║  
║  3  ║  20  ║ a         ║ 0.5             ║  
║  4  ║  20  ║ b         ║ 1               ║  
╚═════╩══════╩═══════════╩═════════════════╝  

参考

http://stackoverflow.com/questions/35976390/postgres-ratio-to-report-function

https://docs.oracle.com/cd/B19306_01/server.102/b14200/functions124.htm

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍如何基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
7月前
|
Oracle 关系型数据库 数据库
【赵渝强老师】在PostgreSQL中访问Oracle
本文介绍了如何在PostgreSQL中使用oracle_fdw扩展访问Oracle数据库数据。首先需从Oracle官网下载三个Instance Client安装包并解压,设置Oracle环境变量。接着从GitHub下载oracle_fdw扩展,配置pg_config环境变量后编译安装。之后启动PostgreSQL服务器,在数据库中创建oracle_fdw扩展及外部数据库服务,建立用户映射。最后通过创建外部表实现对Oracle数据的访问。文末附有具体操作步骤与示例代码。
280 6
【赵渝强老师】在PostgreSQL中访问Oracle
|
9月前
|
SQL Oracle 关系型数据库
|
11月前
|
SQL 存储 Oracle
【YashanDB观点】论Oracle兼容性,我们需要做什么
我们经常发现,部分国产数据库声称与 Oracle兼容性高达90%,但在实际迁移过程中,仍需要频繁地修改业务应用的代码。为何实现与Oracle高兼容度的数据库产品如此困难?其中一个重要原因是Oracle兼容性不仅是模仿,而是一个非常复杂和工程量庞大的逆向工程。其技术实现的复杂性以及多如牛毛的细节,足以让多数“年轻”的数据库团队望洋兴叹。YashanDB作为一款从核心理论到关键系统均为原创的数据库产品,从构建初期就具备了技术优势,在Oracle兼容性实现上,敢于亮剑并充分发挥工匠精神,不断打磨,努力构筑一个真正形神兼备的数据库产品。以下将从YashanDB SQL引擎技术、Oracle兼容性的开发
|
11月前
|
SQL 存储 Oracle
【YashanDB观点】论Oracle兼容性,我们需要做什么
Oracle兼容性是目前国产数据库的关键任务之一,其直接影响到商业迁移的成本和竞争力。
222 8
|
关系型数据库 Serverless 定位技术
PostgreSQL GIS函数判断两条线有交点的函数是什么?
PostgreSQL GIS函数判断两条线有交点的函数是什么?
907 60
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
2625 3
|
SQL 关系型数据库 C语言
PostgreSQL SQL扩展 ---- C语言函数(三)
可以用C(或者与C兼容,比如C++)语言编写用户自定义函数(User-defined functions)。这些函数被编译到动态可加载目标文件(也称为共享库)中并被守护进程加载到服务中。“C语言函数”与“内部函数”的区别就在于动态加载这个特性,二者的实际编码约定本质上是相同的(因此,标准的内部函数库为用户自定义C语言函数提供了丰富的示例代码)
|
SQL Cloud Native 关系型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
1925 1
|
数据可视化 关系型数据库 MySQL
将 PostgreSQL 迁移到 MySQL 数据库
将 PostgreSQL 迁移到 MySQL 数据库
2488 2
|
SQL 存储 自然语言处理
玩转阿里云RDS PostgreSQL数据库通过pg_jieba插件进行分词
在当今社交媒体的时代,人们通过各种平台分享自己的生活、观点和情感。然而,对于平台管理员和品牌经营者来说,了解用户的情感和意见变得至关重要。为了帮助他们更好地了解用户的情感倾向,我们可以使用PostgreSQL中的pg_jieba插件对这些发帖进行分词和情感分析,来构建一个社交媒体情感分析系统,系统将根据用户的发帖内容,自动判断其情感倾向是积极、消极还是中性,并将结果存储在数据库中。
1107 1
玩转阿里云RDS PostgreSQL数据库通过pg_jieba插件进行分词

相关产品

  • 云原生数据库 PolarDB
  • 云数据库 RDS PostgreSQL 版
  • 推荐镜像

    更多