热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

同比数据模型环比_同比(环比)在分析模型中的实现

本帖最后由Noah于2015-8-2009:22编辑同比(环比)在分析模型中的实现1)案例说明本文整理用友医疗BQ应用开发过程中提出的部分关键问题及其解决方案。2)实际问题在数据统

本帖最后由 Noah 于 2015-8-20 09:22 编辑

同比(环比)在分析模型中的实现

1) 案例说明

本文整理用友医疗BQ应用开发过程中提出的部分关键问题及其解决方案。

2)实际问题

在数据统计分析项目中,经常会有指标需要做同比、环比、增长率等相关指标的对比分析。BQ平台中的语义模型又没有提供相应的方法,多维模型虽有相应的方法但用起来也不是很顺手,那有没有办法可以解决这个问题呢?

3) 问题分析

我们在做数据统计分析项目时,用的工具其实不仅仅只有BQ。做数据库设计的Power Designer、承载数据的Oracle、完成ETL的AE-DI、辅助数据处理的Excel,这些都是我们做统计分析师用到的工具。

既然有这么多工具可用,那BQ解决不了的这个问题是否可以通过其他工具解决呢。在这里建议大家在统计分析项目中注重数据库工具的应用,在这里我们用的是oracle,在其它的项目上也可能是别的数据库工具。数据库具有非常强大的统计分析功能,其在特定领域的功能甚至超越专业的统计软件。

那应用Oracle的什么功能来实现这一需求呢?——自然是SQL及其相关的功能。接下来看下面的分析。

Image 2.png (52.69 KB, 下载次数: 13)

2015-8-20 08:50 上传

图1 数据变化过程图

首先,我们从原始表如何得到①这样一个结构的结果,参考下面的语句:

SELECT 科室 , 金额 , 年份 FROM 数据表 WHERE 年份 IN (2014 , 2015)

其次,如何在①的基础上增加两个自定义列,达到②的效果呢,看下面:

SELECT 科室 , 金额 , 年份 , (如果 年份=2014  显示金额 否则 显示 0) AS 自定义(1)

SELECT 科室 , 金额 , 年份, (如果 年份=2015  显示金额 否则 显示 0) AS 自定义(2)

FROM 数据表 WHERE 年份 IN (2014 , 2015)

然后,将“自定义(1)、自定义(2)“改为”去年(金额)、本年(金额)“,同时将这两个字段按照”科室“分组做合计运算,既可以得到③的结果,具体脚本参照下面:

SELECT 科室 ,SUM(如果 年份=2014  显示金额 否则 显示 0) AS 去年(金额)

SELECT 科室 , SUM(如果 年份=2015  显示金额 否则 显示 0) AS 本年(金额)

FROM 数据表 WHERE 年份 IN (2014 , 2015)金额

GROUP BY 科室

按照上面的思路,便可以用SQL获取一个去年同期的对比指标。同理,上期环比指标也可以用类似的方法实现。当本期、同期、上期三个指标完成配置后,通过SQL公式来实现增长率就不难了。那这个构思如何与BQ平台衔接,如何具体在BQ中实现呢?

4) 具体实现

现在我们来介绍,如何通过可拖放的语义模型设计器实现上面所描述的内容。在具体操作之前,我们先看一下实际的数据结构是什么样的。

Image 3.png (65.86 KB, 下载次数: 13)

2015-8-20 08:53 上传

图2 事实表FACT_SF_LEIXING数据结构

Image 4.png (78.21 KB, 下载次数: 10)

2015-8-20 08:53 上传

图3 事实表FACT_SF_LEIXING数据示例

Image 5.png (99.81 KB, 下载次数: 20)

2015-8-20 08:54 上传

图4 日期维表DIM_DATE数据示例

Image 6.png (62.5 KB, 下载次数: 14)

2015-8-20 08:55 上传

图5 科室维表DIM_ORGGROUP数据示例

下面进入”数据处理平台->元数据管理->数据仓库建模工具“节点,然后通过工具栏中的”批量导入数据表“工具,将对应数据仓库数据源下的FACT_SF_LEIXING、DIM_DATE、DIM_ORGGROUP三张表导入到BQ系统中。此处导入数据表的目的,是方便后续在语义模型中引用这三张表,其好处是方便鼠标操作、数据库中已翻译的表名、列名可在语义模型中自动被引用。

Image 7.png (75.37 KB, 下载次数: 10)

2015-8-20 08:55 上传

图6 元数据管理配置

然后进入”数据处理平台->语义建模->语义建模工具“节点,新建一个语义模型,模型编码为”EXAMPLE01“,模型名称为”同比应用案例“。保存模型定义后,打开模型设计器,通过”选择表->元定义“节点将前面导入BQ系统的FACT_SF_LEIXING、DIM_DATE、DIM_ORGGROUP三张表引入模型,如下图所示。

Image 8.png (24.56 KB, 下载次数: 12)

2015-8-20 08:56 上传

图7 语义模型设计器-选择表

接下来进入”连接条件“,配置三个表间的链接关系【收费类型FACT_SF_LEIXING.科室PK_ORGGROUP = 科室档案DIM_ORGGROUP.科室编码DIMCODE】、【收费类型FACT_SF_LEIXING.日期编码PK_DATE = 日期维表DIM_DATE.日期编码DIMCODE】。

Image 9.png (24.83 KB, 下载次数: 14)

2015-8-20 08:57 上传

图8 语义模型设计器-连接条件

完成后进入”选择字段“,在界面下方查询参数选项卡中新建参数【iYear年份】,将”科室档案.科室“字段引入模型,然后新建【CurrentPeriod本期(金额)】字段,其表达式为:

SUM ( CASE  WHEN  DIM_DATE.YYYYCODE  =  PARAMETER  ( 'iYEAR' )

THEN  FACT_SF_LEIXING.JINE   ELSE  0  END  )

同理新建【OverPeriod同期(金额)】字段,其表达式为:

SUM ( CASE  WHEN  DIM_DATE.YYYYCODE  = PARAMETER ( 'iYEAR' )  -  1

THEN  FACT_SF_LEIXING.JINE   ELSE  0  END  )

Image 10.png (44.88 KB, 下载次数: 13)

2015-8-20 08:57 上传

图9 语义模型设计器-选择字段

最后在”描述器“选项卡配置查询条件,查询条件脚本参照为::

DIM_DATE.YYYYCODE = PARAMETER ( 'iYEAR' )

OR

DIM_DATE.YYYYCODE = PARAMETER ( 'iYEAR' )  -  1

Image 11.png (30.8 KB, 下载次数: 15)

2015-8-20 08:58 上传

图10 语义模型设计器-描述器

模型完成后数据预览结果如下图所示:

Image 12.png (57.36 KB, 下载次数: 13)

2015-8-20 08:59 上传

图11 指标配置同比效果图



推荐阅读
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
author-avatar
zvan
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有