操作SSAS数据库的方法有非常多,是否有一种能够方法能够通过脚本自己主动去做这些事呢,比方处理分区,创建备份以及监视SSAS的执行状况。

 

原文地址:

http://www.mssqltips.com/sqlservertip/2937/using-powershell-for-sql-server-analysis-services-tasks--part-1/

 

 

PowerShell作为命令行工具来自己主动化处理SSAS任务就是一个不错的选择。由于是环绕SSAS处理任务的话题。所以阅读此篇须要具备一些SSAS的基础知识,这里我们使用SQL Server 2012。

此篇将介绍例如以下内容:

  • 启动PowerShell
  • 通过PowerShell导航而且查看SSAS对象
  • 通过PowerShell执行些基础指令
  • 处理SSAS的一个分区

 

本文使用SQL Server 2012的Adventureworks演示样例数据库,有能够在这里下载到这个演示样例库:

http://msftdbprodsamples.codeplex.com/releases/view/55330

 

開始

  1. 在開始菜单下,点击Run选项。或者Windows键+r。

  2. 在执行窗口中输入sqlps启动SQL Server下的PowerShell。

  3. 输入GCI命令查看PowerShell下的对象列表。

    GCI命令的含义是获取全部子对象,跟DOS时代下的dir命令非常像,所以这里你也能够相同能够使用LS或者DIR获取相同的结果。从结果中能够看到,SQL Server PowerShell能够让你自己主动以自己主动化的方式去处理SQL Server数据引擎的任务。策略,数据集,SQL Server集成服务任务以及SQL Server分析服务任务。

    此篇我们将集中SSAS任务。

  4. 使用例如以下命令进入到分析服务文件夹中。

    CD sqlas

    这里的CD命令跟DOS下的相同。

  5. 关于GCI的更过信息。能够输入例如以下命令获取帮助:

    get-help gci –detailed

 

分区操作

SSAS多维数据库下包括Cubes立方体,Cubes下又包括度量值以及度量值分区。

下图展示了其层次结构。

接下来使用CD命令移动到分区文件夹下。

cd servername\DEFAULT\databases\AdventureWorksDW2012Multidimensional-EE\cubes\Adventure Works\MeasureGroups\Internet Orders\Partitions

  • Servername就是Windows Server的名称。

  • Default是SSAS服务实例的名称。

  • AdventureWorksDW2012Multidimensional-EE是数据库名称。

  • AdventureWork是立方体名称。
  • Internet Orders是度量值组名称。
  • 最后我们就能够获取到其下的分区信息。当一个分析服务数据库太大的时候我们会考虑将其拆分成不同的分区:

 

使用分区对数据进行拆分。能够通过并行的方法提高处理的速度,而且对于相关的查询性能也会有提高。

接下来通过GCI命令列出全部的分区信息.

我们能够看到分区名称,预计行数以及处理的模式。在Adventureworks立方体中分区是依照年来进行拆分的。

每一个分区的行数默认是没有被计算的所以看到的是0。

处理模式是分区的处理方式,Regular模式意味着数据和聚合都会被处理。第二种Lazy聚合意味着数据首先会被处理,聚合在随后的后台进程创建。这个设置对数据以及减少索引创建是非常有帮助的,由于索引的创建会有额外的性能开销。

能够通过Get-member的方法获取分区下的全部成员。

LS | Get-Member

Get-Member命令用于列出一个对象支持的属性和方法。

在这里就是列出分区下所支持的属性和方法。

比方能够看到分区名。LastProcessed时间以及分区的EstimatedSize:

LS| SELECT NAME, LASTPROCESSED, ESTIMATEDSIZE

假设要处理一个指定的分区那么就能够使用以下的命令:

Invoke-ProcessPartition -Name "Internet_Orders_2006" -MeasureGroupname "Internet Orders" -CubeName "Adventure Works" -database "AdventureWorksDW2012Multidimensional-EE" -ProcessType "ProcessFull"

这个命令会处理Adventureworks下Internet Orders度量值组名为"Internet_Order_2006"的分区,而且是以全量的方式来处理。

在SQL Server 2012 SP1的这个版本号,当我们执行完这个命令然后再执行"LS|SELECT NAME, LASTPROCESSED, ESTIMATEDSIZE"。默认信息是没有更新的。

须要把PowerShell关闭掉然后再又一次打开再执行这个命令才干够看到更新后的信息。

 

备份SSAS数据库

执行以下的命令能够实现Adventureworks的备份:

backup-asdatabase d:\awdb-20110930.abf "AdventureWorksDW2012Multidimensional-EE" -AllowOverwrite –ApplyCompression

这个命令会备份AdventureWorksDW2012Multidimensional-EE数据库,备份文件名称为awdb-20110930.abf。而且存储在d盘根文件夹下。这个命令相同也会覆盖已经存在的同名备份文件。

此篇演示了怎样启动PowerShell。怎样显示对象下的属性,怎样处理一个分区以及最后怎样备份一个数据库。

下一篇会介绍PowerShell在SSAS下的很多其它操作。

 

 

译注:

SSAS的对象的层次结构比較复杂。详细该怎样进行导航或者在某些对象下能做什么,须要对SSAS数据库的基本结构有一个了解。

PowerShell操作SSAS的方式也是通过AMO的方式。方便通过基于.net的方式来进行操作。

SSAS下玩转PowerShell的更多相关文章

  1. [译]SSAS下玩转PowerShell(三)

    在第一篇中简单介绍了PowerShell,包含基本的一些命令,以及如何打开PowerShell,并且导航到SSAS对象.第二篇中学习了如何使用变量根据当前日期创建SSAS备份,以及如何运行MDX和XM ...

  2. [译]SSAS下玩转PowerShell(二)

    上一篇中简单的介绍了SSAS下的PowerShell,这一篇会演示更多的操作,比如根据当前时间创建备份,使用变量去指定处理哪一个分区,以及用XMLA脚本去创建分区,和在PowerShell中调用Pow ...

  3. [译]SSAS下玩转PowerShell

    操作SSAS数据库的方法有很多,是否有一种可以方法可以通过脚本自动去做这些事呢,比如处理分区,创建备份以及监视SSAS的运行状况. 原文地址: http://www.mssqltips.com/sql ...

  4. Linux下玩转Dota2

    Dota2是一款颇为风靡的即时战略类游戏,去年官方就支持Mac和Linux了,对于习惯Mac和linux平台的孩子们来说,简直感动的泪流满面. 当然,也简直是linux程序猿的福音啊啊! 与Win8. ...

  5. cento7.3下玩转sphinx

    cento7.5下玩转sphinx 1 安装依赖文件 yum install postgresql-libs unixODBC 2 下载 wget http://sphinxsearch.com/fi ...

  6. Windows 下如何调试 PowerShell

    背景 最近在用 PowerShell 的时候,发现一些地方特别有意思.于是就萌生了看源代码的想法,单看肯定不过瘾,调试起来才有意思.于是就有了这个,记录下. 调试 PowerShell 主要分为两种方 ...

  7. 玩转PowerShell第一节——【后台任务处理】-技术&分享

    概述 相信大家对后台任务处理不陌生,比如.Net的后台线程处理,Java的线程处理等等. 而当我们用PowerShell这个强大的工具时怎么样开启后台任务呢,以及怎样处理这些任务呢,本篇将会告诉你Po ...

  8. linux下一键安装 powershell,的bash脚本

    说明 目前,linux下的powershell约等于pash.希望大家专注mono,关注pash. 一键安装脚本包括for centos6,centos7,ubuntu 14.04  ubuntu 1 ...

  9. 【Howie玩docker】-windows下玩docker

    Windows下安装toolbox一直没成功,于是投机取巧,用虚拟机手工打造玩docker的方法. 步骤: 安装虚拟机,安装centos 在win下建立共享文件夹,假如是 f:/share 在cent ...

随机推荐

  1. db2 索引

    索引:可通过 SYSCAT.INDEXES JOIN SYSCAT.INDEXCOLUSE来查询索引的字段有升序ASC和降序DESC,分别表示为SYSCAT.INDEXES的COLNAMES中索引字段 ...

  2. js 异步请求

    <p id="check"> <label>验证码:</label> <input class="vid" id=&q ...

  3. Python 函数(可变参数)

    在python函数中,可以定义可变参数,顾名思义,可变参数就是,传入的参数是可变的例如,给定一组数字a,b,c...  请计算a2 + b2 + c2 + …… 要定义出这个函数,我们必须确定输入的参 ...

  4. @Transactional(readOnly=true) in Spring

    http://www.skill-guru.com/blog/2010/12/19/transactionalreadonlytrue-in-spring/ @Transactional(readOn ...

  5. linux dns 工具包 -- bind-utils

    https://www.cnblogs.com/274914765qq/p/4817941.html

  6. 【转】MYSQL-CLUSTER-7.5搭建数据库集群

    阅读目录 前言 mysql cluster中的几个概念解释 架构图及说明 下载mysql cluster 安装mysql cluster之前 安装配置管理节点 安装配置数据和mysql节点 测试 启动 ...

  7. Spark2 Random Forests 随机森林

    随机森林是决策树的集合. 随机森林结合许多决策树,以减少过度拟合的风险. spark.ml实现支持随机森林,使用连续和分类特征,做二分类和多分类以及回归. 导入包 import org.apache. ...

  8. python3之编码详解

    一,python2与python3的区别 1)python2可以不用括号() python3必须加括号 2)python2中有range()有序列表,xrange()生成器 python3中只有ran ...

  9. Mysql 全文搜索 Match Against用法

    全文检索在 MySQL 中就是一个 FULLTEXT 类型索引.FULLTEXT 索引用于 MyISAM 表,可以在 CREATE TABLE 时或之后使用 ALTER TABLE 或 CREATE ...

  10. CentOS搭建内网NTP服务器

      在企业内部网络,不是所有的服务器都可以连接外网,需要搭建一台可以连接外网的服务器用于NTP服务器 安装环境查看 安装ntp yum -y install ntp 修改配置文件 driftfile ...