在2005中使用DrillThrough函数

数据仓库、数据挖掘系统的显著优势之一是可以在分析的过程中对某个数据DrillThrough to detail。数据仓库较之普通数据库系统,对数据仓库的查询分析要比数据库快许多,这是因为数据仓库在ETL过程中已经对Integrating的数据源做了各种各样的预先统计处理,并增加了多倍的额外空间保存这些处理结果,才取得了对查询的快速反映优势。这也就是常说的“以空间换时间”。在OLAP分析的时候,也可以使用DrillThrough函数对数据源进行分析。
o_toDetail.JPG


DrillThrough函数是MDX常用函数之一,跟通常MDX执行ExecuteCellSet并返回CellSet对象不同的是,使用了DrillThrough关键字的MDX只能ExecuteReader返回DataReader

1.        是否允许DrillThrough的权限设置集成在role的“管理角色”中。这点跟AS2000有比较大的区别。在AS2000中,仅对各个cube设置是否允许DrillThrough,所有role具有相同的是否允许DrillThrough的权限;在AS2005中设置更加明细,可以分别对各个role进行是否允许DrillThrough的设置。

2.        AS2000相同的是,DrillThough的对象依然是单个的cell。该cell可以是叶子水平的,也可以是基础度量的聚合cell。所以规定Select部分的每个on axis从句对应的member都是单一的。如:

DRILLTHROUGH

select

{[Measures].[Internet Sales Amount]} on Axis(0),

{[Date].[Calendar].[Month].&[2004]&[3]} on Axis(1),

{[Geography].[Geography].[Country].&[United States]} on Axis(2),

{[Product].[Product Categories].[Subcategory].[Mountain Bikes]} on

Axis(3)

FROM [Adventure Works]

或者select从句为空,在where从句指定。上句跟如下语句是等效的:

DrillThrough select  FROM [Adventure Works]

WHERE

(

[Measures].[Internet Sales Amount],

[Date].[Calendar].[Month].&[2004]&[3],

 [Geography].[Geography].[Country].&[United States]

,[Product].[Product Categories].[Subcategory].[Mountain Bikes]

))

3.        组成上述cell的各个维度都不允许有计算成员。没有做任何限制的维度默认都是defaultMember,如果该defaultMember含有计算成员,必须特别指定其他非计算成员。比如,度量维度的默认成员是计算成员,则必须在select或者where部分特别指定measures的成员([Measures].Members.Item(0)

4.        DrillThrough跟维度的类型没有关系。如果DrillThrough的是父子关系的层次结构的父成员,则返回的结果将是所有组成该cell的行,包括子成员。

5.        AS2005新增Return从句以限定返回的列。举个例子:

DrillThrough

select (

[Measures].[Internet Sales Amount],

[Date].[Calendar].[Month].&[2004]&[3],

[Geography].[Geography].[Country].&[United States] ,

[Product].[Product Categories].[Subcategory].[Mountain Bikes]

) on 0

from

[Adventure Works]

Return

[$Date].[Date],

KEY([$Product].[Style]),

[Internet Sales].[Internet Sales Amount],

[Internet Sales].[Internet Tax Amount]


o_returnControl.JPG

6. 2000中,DrillThrough查询的是具体的数据库表,所以需要SqlConnection,而2005可以直接查询仓库系统,所以直接AdomdConnection


None.gif   public  DataTable DrillThrough( string  mdx,AdomdConnection adomdConn)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            DataTable schema 
= new DataTable();
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                adomdConn.Open();
InBlock.gif                
using (AdomdCommand command = new AdomdCommand(mdx, adomdConn))
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    
using (AdomdDataReader reader = command.ExecuteReader())
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
dot.gif{
InBlock.gif                        
//output the column information
InBlock.gif
                        DataTable schema = reader.GetSchemaTable();
InBlock.gif                        
foreach (DataRow row in schema.Rows)
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{
InBlock.gif                            dt.Columns.Add(row[
0].ToString());
ExpandedSubBlockEnd.gif                        }

InBlock.gif                       
InBlock.gif                        
while (reader.Read())
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{
InBlock.gif                            DataRow dr 
= dt.NewRow();
InBlock.gif                            
for (int i = 0; i < reader.FieldCount; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif                            
dot.gif{
InBlock.gif                                dr[i] 
= reader[i];
ExpandedSubBlockEnd.gif                            }

InBlock.gif                            dt.Rows.Add(dr);
ExpandedSubBlockEnd.gif                        }

ExpandedSubBlockEnd.gif                    }

ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif            
finally
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                adomdConn.Close();
ExpandedSubBlockEnd.gif            }

InBlock.gif            
return dt;
ExpandedBlockEnd.gif        }


转载于:https://www.cnblogs.com/anchky/archive/2006/12/17/DrilllThrough1.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值