> 데이터 베이스 > MySQL 튜토리얼 > MDX示例:统计各产品每个季度的销售排名

MDX示例:统计各产品每个季度的销售排名

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-07 15:14:43
원래의
1660명이 탐색했습니다.

ITPUB数据仓库与数据挖掘论坛用户Damon__Li问: 统计 各种 产品 在本年 每个 季度 的 销售 排名 ,(现在有日期、 产品 维度和 销售 额度量)大体显示如下 Q1 Q2 Q3 Q4 销售 额 排名 销售 额 排名 销售 额 排名 销售 额 排名 产品 1 3000 2 2000 3 5000 1 40

ITPUB数据仓库与数据挖掘论坛用户Damon__Li问:

统计各种产品在本年每个季度销售排名,(现在有日期、产品维度和销售额度量)大体显示如下
                         Q1                    Q2                    Q3                  Q4
                销售额    排名     销售额    排名      销售额   排名    销售额   排名
产品1         3000       2         2000      3          5000     1         4000    1
产品2         4000       1         3000      2          4000     2         2000    3
产品3         2000       3         4000      1          3000     3         3000    2
…….
请熟悉MDX的前辈指点,提供思路。

10多年前就搞MDX,尽管现在不从事这方面工作了,但这种问题看到就手痒。

以下是在SSAS 2008 R2 及SQL Server [Adventure Works]示例数据库(在Codeplex有下载)给出的求解(示例中,季度位于时间维度第2层级):

统计各种产品在本年每个季度销售排名.MDX

1

2

3

4

5

6

7

8

9

10

11

12

13

14

WITH

    MEMBER [Measures].[SalesRank] AS

        RANK(

            [Product].[Product Categories].currentmember,

            [Product].[Product Categories].[AllProducts].children ,

            [Measures].[Sales Amount]

        )

 

SELECT

    {DESCENDANTS([Date].[Calendar].[CalendarYear].&[2007],2)}

    *{[Measures].[Sales Amount],[Measures].[SalesRank]} ON0,

    [Product].[Product Categories].[AllProducts].children ON1

FROM

    [Adventure Works]

以下是在SSAS中执行的情况,可以将[Date].[Calendar].[Calendar Year].&[2007]用[Date].[Calendar].CurrentMember替换,改为在WHERE语句里指定年度[Date].[Calendar].[Calendar Year].&[2007],放在查询切片中后,利于在切片中指定查询条件。

<strong>统计</strong>各种<strong>产品</strong>在本年<strong>每个</strong><strong>季度</strong>的<strong>销售</strong><strong>排名</strong>

统计各种产品在本年每个季度销售排名

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿