Microsoft SQL Server SSAS的本地多维数据集(即Local Cube,也叫脱机多维数据集)和本地挖掘模型(Local Mining Models)允许在客户端机器上脱机执行离线分析(多维分析与数据挖掘),从而对有离线分析要求(能够在断开网络连接的情况下脱离SSAS服务器进行数据分析)的软件开发提供了一种备选手段。

本地多维数据集联机/脱机示意

1、创建本地多维数据集

创建本地多维数据集有多种方式,按默认约定生成的本地文件扩展名为*.cub。

1)  从SQL Server服务器上现有的SSAS多维数据集(Cube)创建

在这种方式下,创建的结果是选定的源Cube的子集,可以在创建语句中指定Local Cube中包含的度量值、维度,还可以指定维度的切片和切块等。

源Cube中需要包含在Local Cube中的计算成员和命名集无需指定,SSAS在生成Local Cube时将执行语法分析,在Local Cube中能够满足依赖关系的计算成员和命名集会被自动包含进来,而不符合依赖关系者将会在生成Local Cube时自动排除。

具体有两种比较方便的手段:

A)MDX语句

从现有SSAS Cube创建时,可使用”Create global cube” MDX语句创建Local Cube,如果数据量大,最好直接在SSAS服务器上本地执行MDX语句。

B)Excel操作

用Excel创建local Cube,该方法很方便,但只适合数据量很小的情况。步骤是:

通过Excel的“数据➡来自其他数据源➡来自Analysis Service”菜单项,启动连接SSAS数据源的向导窗体后,一路向后随意点击生成pivottable,然后通过“数据透视表工具➡OLAP工具➡脱机OLAP”菜单项启动excel“创建脱机数据文件”的向导。

2)  从关系数据库,从头定义、创建和填充多维数据集

这种方式需要使用 Analysis Services Scripting Language(ASSL)脚本语言,能够构造出非常强大、灵活的解决方案。

以下是从SQL Server 2008/2008R2/2012附带的Adventure Works多维数据库,用MDX语句创建Local Cube的示例。

1)示例1——从SSAS服务器上的[Adventure Works] 示例多维数据集创建Local Cube,结果是“Reseller Sales”度量值组的子集。

创建Local Cube
1
2
3
4
5
6
7
8
CREATE GLOBAL CUBE [LocalReseller]
Storage 'D:\temp\LocalAWReseller.cub'
FROM [Adventure Works]
(
MEASURE  [Adventure Works].[Reseller Sales Amount],
DIMENSION [Adventure Works].[Reseller],
DIMENSION [Adventure Works].[ Date ]
)

2)示例2——从SSAS服务器上的[Adventure Works] 示例多维数据集创建Local Cube,结果是 “Sales Summary”度量值组的子集

创建Local Cube
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
CREATE GLOBAL CUBE [LocalSalesSummary]
Storage 'D:\temp\LocalSalesSummary.cub'
FROM [Adventure Works]
(
//计算成员无法包含在 Local Cube
          //MEASURE  [Adventure Works].[Average Sales Amount],
//MEASURE  [Adventure Works].[Average Unit Price],
//MEASURE  [Adventure Works].[Expense to Revenue Ratio],
MEASURE  [Adventure Works].[Extended Amount],
MEASURE  [Adventure Works].[Freight Cost],
//MEASURE  [Adventure Works].[Gross Profit],
//MEASURE  [Adventure Works].[Gross Profit Margin],
MEASURE  [Adventure Works].[ Order Quantity],
//MEASURE  [Adventure Works].[Ratio to All Products],
//MEASURE  [Adventure Works].[Ratio to Parent Product],
MEASURE  [Adventure Works].[Sales Amount],
MEASURE  [Adventure Works].[Standard Product Cost],
MEASURE  [Adventure Works].[Tax Amount],
MEASURE  [Adventure Works].[Total Product Cost],
         DIMENSION [Adventure Works].[ Date ],
DIMENSION [Adventure Works].[Delivery Date ],
//DIMENSION [Adventure Works].[Destination Currency],
DIMENSION [Adventure Works].[Product],
DIMENSION [Adventure Works].[Promotion],
DIMENSION [Adventure Works].[Sales Channel],
//DIMENSION [Adventure Works].[Sales Summary Order Details],
DIMENSION [Adventure Works].[Sales Territory],
DIMENSION [Adventure Works].[Ship Date ],
DIMENSION [Adventure Works].[Source Currency]
)

2、使用本地多维数据集

针对不同应用目的,客户端应用程序可通过以下几种方式执行加载本地多维数据集引擎、创建本地多维数据集、打开本地多维数据集、查询本地多维数据集等操作。

1)OLE DB for OLAP

2)ADMOD.NET

3)Analysis Management Objects (AMO)

在使用本地多维数据集时,如果不想在客户端机器上安装SQL Server SSAS服务器/客户端应用,则可以访问微软网站,下载SQL Server 2008/2008R2/2012特性包(sql server feature pack)中的ADOMD.net、AMO、Ole DB for Olap等组件的单独安装文件,在客户端安装即可支持。

以下ADMOD.NET方式使用Local Cube的示例

使用Local Cube
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
//声明
 
using adoMdClient = Microsoft.AnalysisServices.AdomdClient;
 
private adoMdClient.AdomdConnection cnAdomd;
 
……
 
//连接 Local Cube
 
cnAdomd = new Microsoft.AnalysisServices.AdomdClient.AdomdConnection();
cnAdomd.ConnectionString = “Data Source= D:\ temp \LocalAWReseller.cub”;
cnAdomd. Open ();
 
……
 
//提交MDX查询并获取多维查询结果
adoMdClient.AdomdCommand mdxCommand = cnAdomd.CreateCommand();
mdxCommand.CommandText = “ select [Measures].[Sales Amount] on 0, [Product].[Product Categories].[ All Products].Children on 1 from [Adventure Works]”;
adoMdClient.CellSet adomdCellSet = mdxCommand.ExecuteCellSet();

3、补充说明

关于刷新和重新创建脱机多维数据集文件,本地多维数据集在创建、使用、安全性等方面的约束条件等话题,请查阅SSAS手册详细了解。

4、附图:Excel创建Local Cube的示意图

在Excel中创建本地多维数据集-1

在Excel中创建本地多维数据集-2

创建和使用SQL Server SSAS本地多维数据集的更多相关文章

  1. 批处理创建数据库(Sql Server)

    ylbtech-Miscellaneos:批处理创建数据库(Sql Server) 1.A,资源(Resource) - 创建数据返回顶部 1.A.1,InstallDatabases.cmd - 编 ...

  2. Sql Server把本地数据库传到服务器数据库

    上一篇文章我们已经把网站布署到服务器中了,如果是动态网站肯定是有数据库的,接下来通过Sql Server把本地数据库上传到服务器数据库中. 打开Sql Server连接本地数据库,选中要导出的数据库, ...

  3. 微软BI 之SSAS 系列 - 多维数据集维度用法之三 多对多维度 Many to Many

    开篇介绍 对于维度成员和事实数据直接的关系看到更多的可能还是一对一,一对多的关系.比方在事实维度(或退化维度)中一个订单和明细号组合而成的ID,对应的就是事实表中的一条数据,这就是一对一的关系.比方说 ...

  4. 微软BI 之SSAS 系列 - 多维数据集维度用法之二 事实维度(退化维度 Degenerate Dimension)

    这篇文章是基于上一篇 SSAS 系列 - 多维数据集维度用法之一 引用维度 Referenced Dimension 继续讲解多维数据集维度用法中的事实维度. 事实维度,顾名思义就是把事实表 Fact ...

  5. Sql Server 的本地时间和UTC时间

    一,本地时间和UTC时间 本地时间 世界的每个地区都有自己的本地时间,整个地球分为二十四时区,每个时区都有自己的本地时间. UTC时间 在国际无线电通信中,为统一而普遍使用一个标准时间,称为通用协调时 ...

  6. Microsoft SQL Server 获得本地帮助方法

    微软的自带的帮助文档不管是对于开发人员还是DBA都是相当的重要.一般在有网络的状况下可以直接访问 http://msdn.microsoft.com/query/dev10.query?appId=D ...

  7. 如何创建和还原SQL Server 2005数据库?

    在还原SQL Server 2005数据库文件之前,建议先把要还原的数据库文件复制粘贴到某个盘的根目录下,这样便于一会儿找到相关的文件,比如C盘. 先打开SQL Server 2005的Microso ...

  8. 如何创建和还原SQL Server 2000数据库?

    说明:这篇文章是几年前我发布在网易博客当中的原创文章,但由于网易博客现在要停止运营了,所以我就把这篇文章搬了过来,虽然现如今SQL Server 2000软件早已经过时了,但仍然有一部分人在使用它,尤 ...

  9. SQL Server在本地计算机上用SSMS(SQL Server Management Studio)登录不上,错误消息:(Microsoft SQL Server, Error: 18456)

    今天遇到了一个奇怪的问题,公司目前在SQL Server上都采用AD域账号登录,由于账号人数众多,所以我们建立了一个AD Group(域组),将大家的AD账号加入了这个AD Group,然后我们将这个 ...

随机推荐

  1. POJ 2777 Count Color(线段树+位运算)

    题目链接:http://poj.org/problem?id=2777 Description Chosen Problem Solving and Program design as an opti ...

  2. ARC注意的泄漏问题

    --------- block中常见的泄漏问题 代码中block经常用到.例如网络请求?一些图形分析处理等,就是比较耗时的操作,多线程gcd然后进行操作. 这个时候,会使用block进行处理,然后调用 ...

  3. 移动应用跨平台框架江湖将现终结者?速来参拜来自Facebook的React Native

    React Native使用初探 February 06 2015 Facebook让所有React Conf的参与人员都可以初尝React Native的源码---一个编写原生移动应用的方法.该方法 ...

  4. uva 11181 - Probability|Given

    条件概率公式:P( A|B ) = P( AB ) / P( B ) 表示在事件B发生的前提,事件A发生的可能性: 问题的: 复位事件E:r个人买东西: 事件Ei:文章i个人买东西: 的要求是P( E ...

  5. leetcode第40题--First Missing Positive

    题目: Given an unsorted integer array, find the first missing positive integer. For example,Given [1,2 ...

  6. 使用GDB调试器(一)

    使用GDB调试器 GDB概要---- GDB是GNU开源组织公布的一个强大的UNIX下的程序调试工具.也许,各位比較喜欢那种图形界面方式的,像VC.BCB等IDE的调试,但假设你是在UNIX平台下做软 ...

  7. MEF简介及简单的Demo

    MEF简介及简单的Demo 文章开始之前,首先简单介绍一下什么是MEF,MEF,全称Managed Extensibility Framework(托管可扩展框架).单从名字我们不难发现:MEF是专门 ...

  8. 仿javascript中confirm()方法的小插件

    10天没有写博客了,不知道为什么,心里感觉挺不舒服的,可能这是自己给自己规定要去完成的事情,没有按照计划执行,总会心里不怎么舒服.最近事情挺多的,终于今天抽空来更新一下博客了. 今天写的是一个小插件. ...

  9. ASP.NET MVC + 百度富文本编辑器 + EasyUi + EntityFrameWork 制作一个添加新闻功能

    本文将交大伙怎么集成ASP.NET MVC + 百度富文本编辑器 + EasyUi + EntityFrameWork来制作一个新闻系统 先上截图: 添加页面如下: 下面来看代码部分 列表页如下: @ ...

  10. ExtJs之表格控件入门

    extjs的表格功能非常强大,包括了排序,缓存,拖动,隐藏某一列,自动显示行号,列汇总,单元格编辑等实用功能.表格由类Ext.grid.GridPanel定义,继承自Panel,其xtype为grid ...