mdx常用计算之环比与同期比

2023-12-28 08:40
文章标签 计算 常用 环比 mdx 同期

本文主要是介绍mdx常用计算之环比与同期比,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

同比和环比计算是企业应用、电子商务应用中常用的计算方法,也是常用的数据分析手段。写这篇文章也是因为最近在学习MDX相关的一些计算方法的同时回想到原来我在项目中使用过的一些类似的,利用SQL来完成的统计计算,如前期和当期的差额,趋势等。比较之下,利用MDX来完成这些计算比用SQL来做要简单清晰得多,当然这是毫无疑问的。原来利用几十行甚至上百行SQL来完成的计算(有时还要借助程序代码来完成计算)现在用MDX只要十几行左右就可以完成。因此,MDX所带来的好处是很明显的。本文就主要介绍利用MDX进行同比和环比计算。   

    现在进入正题,我首先介绍一下本文使用到的多维数据集(在说明MDX查询之前对多维数据集作一些介绍有利于理解)。本文中用到的多维数据集是通过SQL SERVER 2005提供的案例数据仓库AdventureWorksDW创建的。多维数据集的名称是AW Cube。本文介绍的同比和环比查询所涉及到的维度包括[Ship Date](时间维度)和名称为[Sales Amount]的度量值。因为是一个用于学习的案例,所以结构比较简单,可以通过适当地修改MDX查询(如进行切片、切块、下钻、上卷操作)来达到实际使用目的。

    在时间维度中包括两个层次:[Ship Date].[h_TimeYSQMD];[Ship Date].[h_TimeYWM]。本文主要用到的是前者。这个层次结构为:CalendarYear->CalendarSemester->CalendarQuarter->MonthNumberOfYear-> DayNumberOfMonth。     

    接下来再说明一下什么是环比及同比。简单地说,环比就是逐期的数据比较;同比就是同期的数据比较。例如:将今年的下半年数据与上半年数据相比较;将今年的五月的数据与四月的数据相比较;将今年第三季度的数据与今年的第二季度相比较,这些都是环比。将今年的数据与去年的数据比较;将今年五月的数据与去年五月的数据比较;将今年第一季度的数据与去年第一季度的数据比较,这些都是同比。

 

同比的MDX代码如下(计算成员):


CREATE MEMBER [AW Cube].[Parallel Period Compare] AS 
[Measures].[Sales Amount]-
    
[Measures].[Sales Amount],ParallelPeriod( 
        
[Ship Date].[h_TimeYSQMD].[CalendarYear]
        
1
        
[Ship Date].[h_TimeYSQMD].CurrentMember 
    ) 
), 
FORMAT_STRING
='###,###,###,##0.00' 

 

  在这个计算成员中最为主要的就是那个ParallelPeriod函数,这个函数的功能是返回上一期间中与指定成员具有相同的相对位置的成员。这里将ParallelPeriod函数的结果与度量值组成一个元组,就可以对ParallelPeriod函数计算所得到的结果在指定的度量上进行汇总。这个计算的结果就是返回当期与上一期数据的差额。

 

同比计算成员的测试MDX代码:


SELECT 
{
    
[Ship Date].[h_TimeYSQMD].[CalendarYear].&[2003].&[2]
    
[Ship Date].[h_TimeYSQMD].[CalendarYear].&[2003].&[2].Children 
ON COLUMNS, 

    
[Measures].[Sales Amount]
    
[Parallel Period Compare] 
ON ROWS 
FROM [AW Cube] 

 

  这个查询用于测试上面的同比计算成员。这个查询的目的是显示2003年下半年与2002年下半年的差额以及2003年第三、四季度与前一年三、四季度的差额。SSAS中的查询结果见图一,第一列(列名为2这一列)第一行(Sales Amount这一行)对应的数据是2003年下半年的销售数据,第一列第二行显示的是与2002年下半年的差额,第二列第一行是2003年第三季度的销售数据,第二列第二行是显示的2003年第三季度与2002年第三季度的差额...  

图一:同比查询结果

 

环比计算成员:


CREATE MEMBER [AW Cube].[Cycle Period Compare] AS 
[Measures].[Sales Amount]-
    
[Ship Date].[h_TimeYSQMD].CurrentMember.PrevMember, 
    
[Measures].[Sales Amount] 
), 
FORMAT_STRING
='###,###,###,##0.00'

 

  环比计算成员的定义看起来要比同比计算成员简单一点,环比计算成员中最主要的部分就是[Ship Date].[h_TimeYSQMD].CurrentMember.PrevMember这一句。这一句就表达了环比的定义。通过计算当期与前一期成员与度量值组成的汇总数据得到环比结果,即当期与前一期数据的差额。

 

环比计算成员的测试MDX代码:


SELECT 

    
[Ship Date].[h_TimeYSQMD].[CalendarYear].&[2003].&[2]
    
[Ship Date].[h_TimeYSQMD].[CalendarYear].&[2003].&[2].Children 
ON COLUMNS, 

    
[Measures].[Sales Amount]
    
[Cycle Period Compare] 
ON ROWS 
FROM [AW Cube] 

 

  这个查询用于测试上面的环比计算成员。这个查询可以显示2003年下半年与上半年的差额以及2003年三季度与二季度的差额、四季度与三季度的差额。查询的结果见图二,第一列(列名为2这一列)第一行(Sales Amount这一行)对应的数据是2003年下半年的销售数据,第一列第二行对应的数据是与上半年的差额。第二列第一行是2003年三季度的销售数据,下面一行是与第二季度的差额...  

图二:环比查询结果

这篇关于mdx常用计算之环比与同期比的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/545451

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Java中Arrays类和Collections类常用方法示例详解

《Java中Arrays类和Collections类常用方法示例详解》本文总结了Java中Arrays和Collections类的常用方法,涵盖数组填充、排序、搜索、复制、列表转换等操作,帮助开发者高... 目录Arrays.fill()相关用法Arrays.toString()Arrays.sort()A

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的