科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道如何用Oracle RATIO_TO_REPORT计算总数百分比

如何用Oracle RATIO_TO_REPORT计算总数百分比

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

传统上,Oracle计算百分比的方法是在总计报告的子查询中使用SUM函数总计报告,然后把那个结果放到细节表中相除来计算百分比。你还可以用一个子查询作为SELECT语句表达式,RATIO_TO_REPORT解析函数使得这种类型的查询更容易编码。

作者:开发者在线 来源:开发者在线 2007年7月27日

关键字: Bob Watkins 数据库 ORACLE

  • 评论
  • 分享微博
  • 分享邮件

在本页阅读全文(共3页)

除报告详细数据外,许多报告中还包括每行总数的百分比。例如,每名客户的订单相对于总订单的百分比,或每位销售代表的销售额相对于总销售额的百分比。

传统上,Oracle计算百分比的方法是在总计报告的子查询中使用SUM函数总计报告,然后把那个结果放到细节表中相除来计算百分比。你还可以用一个子查询作为SELECT语句表达式:

RATIO_TO_REPORT解析函数使得这种类型的查询更容易编码。Oracle 8i中引入了这个函数,它的格式如下:

RATIO_TO_REPORT (expr) OVER (query_partition_clause)

列表A说明一个简单的例子。对163号销售代表来说,每位客户的销售额占这名销售代表的总销售额的百分比是多少呢?在这种情况下,查询分区子句(partition clause)为空,因此得到的结果是对返回的所有行计算得出。列表B增加了一个查询分区子句,进一步按客户细分报告。

PARTITION BY customer_id子句重新安排每位客户的总数,进而说明每名客户的哪次订单最为关键。你可以查看客户102的情况,他的两个订单相对平衡;但客户103的一个订单占这名客户总订单额的很大一部分。

Oracle解析可帮助你节省编码时间,并在执行过程中生成更加有效的查询。

Bob Watkins(OCP、MCDBA、MCSE、MCT)是一位有25年经验的计算机专业人士,从事过技术培训师、顾问与数据库管理员等职。现在他在达拉斯/沃尔斯堡地区的B. Watkins数据库顾问和培训公司担任高级顾问兼管理合作伙伴。

责任编辑:德东

查看本文国际来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章