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

相关文章

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

常用的jdk下载地址

jdk下载地址 安装方式可以看之前的博客: mac安装jdk oracle 版本:https://www.oracle.com/java/technologies/downloads/ Eclipse Temurin版本:https://adoptium.net/zh-CN/temurin/releases/ 阿里版本: github:https://github.com/