SQL Server 2008 MDX应用之组装有序集合

数据库 SQL Server
本文我们主要介绍了SQL Server 2008 MDX应用之组装有序集合的实例,通过实例让我们来了解一下这一过程吧,希望能够对您有所帮助。

SQL Server 2008 MDX应用之组装有序集合是本文我们主要要介绍的内容,接下来我们通过一些具体的例子来介绍这一过程,希望能够对您有所帮助。

打开MDX查询编辑器,如下:

例6-1

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. {[Product].[Product].[Product].Members} ON ROWS  
  4. FROM [Step-by-Step]; 

查询结果:

我们修改排序,如下:

例6-2

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. Order(  
  4. {[Product].[Product].[Product].Members},  
  5. ([Measures].[Reseller Sales Amount]),  
  6. DESC  
  7. ) ON ROWS  
  8. FROM [Step-by-Step]; 

注意排序字段,这里使用了Order函数(http://msdn.microsoft.com/zh-cn/library/ms145587.aspx)。

例6-3

  1. SELECT  
  2. {  
  3. ([Measures].[Reseller Sales Amount]),  
  4. ([Measures].[Internet Sales Amount])  
  5. } ON COLUMNS,  
  6. Order(  
  7. {[Product].[Product].[Product].Members},  
  8. VBAMDX!ABS(  
  9. ([Measures].[Reseller Sales Amount]) -  
  10. ([Measures].[Internet Sales Amount])  
  11. ),  
  12. DESC  
  13. ) ON ROWS  
  14. FROM [Step-by-Step]; 

注意,我们使用了上一节提到的VBA函数,结果以两列之差的绝对值为排序依据。

SQL Server 2008 MDX应用之组装有序集合

注意:使用Order还可以突破分层限制。

例6-4

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. {[Product].[Subcategory].[Subcategory].Members} ON ROWS  
  4. FROM [Step-by-Step]; 

SQL Server 2008 MDX应用之组装有序集合

例6-5

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. {[Product].[Category].[Category].Members} *  
  4. {[Product].[Subcategory].[Subcategory].Members} ON ROWS  
  5. FROM [Step-by-Step]; 

SQL Server 2008 MDX应用之组装有序集合

再进一步,看一个双排序的例子

例6-6

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. Order(  
  4. {[Product].[Category].[Category].Members} *  
  5. {[Product].[Subcategory].[Subcategory].Members},  
  6. ([Measures].[Reseller Sales Amount]),  
  7. DESC  
  8. ) ON ROWS  
  9. FROM [Step-by-Step]; 

SQL Server 2008 MDX应用之组装有序集合

在上面的查询中,交叉联接使用默认排序,而且后面指定了([Measures].[Reseller Sales Amount])排序,但是大家注意到没有,这一列并没有按照指定的数值排序,为什么呢?因为默认的ASC和DESC是分层的(hierarchical),换句话说,这些元组的前一个成员的排序被保留了。为了打乱这个层次结构,可以使用BASC和BDESC(http://msdn.microsoft.com/zh-cn/library/ms145587(v=SQL.105))。
例6-7

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. Order(  
  4. {[Product].[Category].[Category].Members} *  
  5. {[Product].[Subcategory].[Subcategory].Members},  
  6. ([Measures].[Reseller Sales Amount]),  
  7. BDESC  
  8. ) ON ROWS  
  9. FROM [Step-by-Step]; 

SQL Server 2008 MDX应用之组装有序集合

OK!这下消停了。

顺便,我们提一下Hierarchize函数(http://msdn.microsoft.com/zh-cn/library/ms145981.aspx),该函数可以按层次结构的顺序组织指定集中的成员,返回集的有效多维表达式 (MDX)。

我们看一个例子

例6-8

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. Hierarchize(  
  4. {  
  5. ([Product].[Product Categories].[Subcategory].[Road Bikes]),  
  6. ([Product].[Product Categories].[All Products]),  
  7. ([Product].[Product Categories].[Subcategory].[Mountain Bikes]),  
  8. ([Product].[Product Categories].[Category].[Bikes]),  
  9. ([Product].[Product Categories].[Subcategory].[Touring Bikes])  
  10. }  
  11. ) ON ROWS  
  12. FROM [Step-by-Step]; 

SQL Server 2008 MDX应用之组装有序集合

如果定义POST标志,则 Hierarchize 函数按非自然顺序对一定级别的成员进行排序。 也就是说,子成员优先于他们的父级。

例6-9

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. Hierarchize(  
  4. {  
  5. ([Product].[Product Categories].[Subcategory].[Road Bikes]),  
  6. ([Product].[Product Categories].[All Products]),  
  7. ([Product].[Product Categories].[Subcategory].[Mountain Bikes]),  
  8. ([Product].[Product Categories].[Category].[Bikes]),  
  9. ([Product].[Product Categories].[Subcategory].[Touring Bikes])  
  10. },  
  11. POST  
  12. ) ON ROWS  
  13. FROM [Step-by-Step]; 

SQL Server 2008 MDX应用之组装有序集合

范围操作符:包含一个默认的排序

例6-10

  1. SELECT  
  2. {([Measures].[Reseller Sales Amount])} ON COLUMNS,  
  3. {[Date].[Calendar].[CY 2001]:[Date].[Calendar].[CY 2004]} ON ROWS  
  4. FROM [Step-by-Step];  
  5.  
  6. /*  
  7. Reseller Sales Amount  
  8. CY 2001 $8,065,435.31  
  9. CY 2002 $24,144,429.65  
  10. CY 2003 $32,202,669.43  
  11. CY 2004 $16,038,062.60  
  12. */ 

关于SQL Server 2008 MDX应用之组装有序集合的相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. SQL Server多表查询优化方案总结
  2. SQL Server数据库ISNULL函数的应用实例
  3. SQL Server数据库DATEPART的语法及使用实例
  4. SQL Server根据子节点查询所有父节点的代码示例
  5. SQL Server脏读方式数据提取之NOLOCK和READPAST
责任编辑:赵鹏 来源: 博客园
相关推荐

2011-08-19 14:03:36

SQL Server 检索集合

2011-03-11 10:35:31

SQL锁定SQL Server

2011-02-28 13:19:50

SQL Server SQL死锁

2011-03-11 13:26:32

SQL ServerBlocking阻塞

2011-08-19 15:29:10

SQL Server 元数组

2011-08-19 14:38:22

SQL Server 2008递归查询

2011-08-19 15:48:13

SQL Server 结果集Sets使用技巧

2011-08-19 15:13:36

SQL Server MDX查询

2009-05-18 18:20:14

虚拟化Hyper-VWindows ser

2011-09-01 13:24:42

SQL Server 呈现GeoRSS订阅的Bing Maps

2011-02-18 17:31:18

SQL Server

2011-02-21 13:06:42

Microsoft S

2009-04-16 15:30:15

SQL Server 可用性应用场景

2009-04-16 17:55:15

扩展热插拔SQL Server

2010-06-03 11:39:33

2011-04-07 09:56:53

SQL Server 内存

2009-02-24 13:15:22

FILESTREAM新特性SQL Server

2009-04-16 17:34:19

2009-04-16 18:15:19

动作审核审核活动SQL Server

2009-04-16 17:44:31

点赞
收藏

51CTO技术栈公众号