1、首先要构建一个时间维度表,下面给出通用的构建时间维度的存储过程:

USE [BI_DW]
GO
/****** Object: StoredProcedure [dbo].[proc_Dim_date] Script Date: 05/20/2016 11:35:58 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER proc [dbo].[proc_Dim_date]
as
begin IF OBJECT_ID('dbo.Dim_Date') IS NOT NULL
DROP TABLE dbo.[Dim_Date] CREATE TABLE [dbo].[Dim_Date](
[DateKey] [int] NULL,
[Date] [datetime] NULL,
[Year] [float] NULL,
[Month] [float] NULL,
[Month EN] [nvarchar](50) NULL,
[Month Short EN] [nvarchar](50) NULL,
[Month CN] [nvarchar](50) NULL,
[Day] [float] NULL,
[Quarter] [float] NULL,
[Quarter EN] [nvarchar](50) NULL,
[Quarter CN] [nvarchar](50) NULL,
[Weekday] [float] NULL,
[Weekday CN] [nvarchar](50) NULL,
[Weekday Short EN] [nvarchar](50) NULL,
[Week of Year] [float] NULL,
[Day of Year] [float] NULL,
[SemiYearly] [nvarchar](50) NULL,
[Period of Ten Days] [nvarchar](10) NULL,
[Period of Index] [nvarchar](2) NULL,
[Weekend] [nvarchar](5) NULL
) ON [PRIMARY] SET DATEFIRST 7 --设周日为每周的第一天 --向日期表插入数据
DECLARE @b1 DATETIME
set @b1='2010-01-01' --设置起始日期 WHILE @b1<dateadd(day,2,GETDATE()) --设置截止日期
BEGIN
INSERT INTO dbo.[Dim_Date] (
[DateKey],
[Date],
[Year],
[Month],
[Month EN],
[Month Short EN],
[Month CN],
[Day],
[Quarter],
[Quarter EN],
[Quarter CN],
[Weekday],
[Weekday CN],
[Weekday Short EN],
[Week of Year],
[Day of Year],
[SemiYearly],
[Period of Ten Days],
[Period of Index] ,
[Weekend]
)
VALUES(
CONVERT(NVARCHAR(10),@b1,112), --DateKey 1
@b1, --Date 2
DATEPART(year, @b1), --Year 3
DATEPART(month, @b1), --Month 4
CASE --Month EN 5
when (DATEPART(month, @b1))='' then 'January'
when (DATEPART(month, @b1))='' then 'February'
when (DATEPART(month, @b1))='' then 'March'
when (DATEPART(month, @b1))='' then 'April'
when (DATEPART(month, @b1))='' then 'May'
when (DATEPART(month, @b1))='' then 'June'
when (DATEPART(month, @b1))='' then 'July'
when (DATEPART(month, @b1))='' then 'August'
when (DATEPART(month, @b1))='' then 'September'
when (DATEPART(month, @b1))='' then 'October'
when (DATEPART(month, @b1))='' then 'November'
else 'December'
END,
CASE --Month Short En 6
when (DATEPART(month, @b1))='' then 'Jan'
when (DATEPART(month, @b1))='' then 'Feb'
when (DATEPART(month, @b1))='' then 'Mar'
when (DATEPART(month, @b1))='' then 'Apr'
when (DATEPART(month, @b1))='' then 'May'
when (DATEPART(month, @b1))='' then 'Jun'
when (DATEPART(month, @b1))='' then 'Jul'
when (DATEPART(month, @b1))='' then 'Aug'
when (DATEPART(month, @b1))='' then 'Sep'
when (DATEPART(month, @b1))='' then 'Oct'
when (DATEPART(month, @b1))='' then 'Nov'
else 'Dec'
END,
CASE --Month CN 7
when (DATEPART(month, @b1))='' then N'一月'
when (DATEPART(month, @b1))='' then N'二月'
when (DATEPART(month, @b1))='' then N'三月'
when (DATEPART(month, @b1))='' then N'四月'
when (DATEPART(month, @b1))='' then N'五月'
when (DATEPART(month, @b1))='' then N'六月'
when (DATEPART(month, @b1))='' then N'七月'
when (DATEPART(month, @b1))='' then N'八月'
when (DATEPART(month, @b1))='' then N'九月'
when (DATEPART(month, @b1))='' then N'十月'
when (DATEPART(month, @b1))='' then N'十一月'
else N'十二月'
END,
DATEPART(day, @b1),--day 8
DATEName (qq, @b1),--quarter 9
CASE --quarter en 10
when DATEName (qq, @b1)='' then 'Q1'
when DATEName (qq, @b1)='' then 'Q2'
when DATEName (qq, @b1)='' then 'Q3'
else 'Q4'
END,
CASE --quarter cn 11
when DATEName (qq, @b1)='' then N'一季度'
when DATEName (qq, @b1)='' then N'二季度'
when DATEName (qq, @b1)='' then N'三季度'
else N'四季度'
END,
DATEPART(dw, @b1),--Weekday 12
CASE --Weekday CN 13
when DATEPART(dw, @b1)=1 then N'星期日'
when DATEPART(dw, @b1)=2 then N'星期一'
when DATEPART(dw, @b1)=3 then N'星期二'
when DATEPART(dw, @b1)=4 then N'星期三'
when DATEPART(dw, @b1)=5 then N'星期四'
when DATEPART(dw, @b1)=6 then N'星期五'
else N'星期六'
END,
CASE --Weekday Short EN 14 --注意,周日是第一天.
when DATEPART(dw, @b1)='' then 'Sun'
when DATEPART(dw, @b1)='' then 'Mon'
when DATEPART(dw, @b1)='' then 'Tue'
when DATEPART(dw, @b1)='' then 'Wed'
when DATEPART(dw, @b1)='' then 'Thu'
when DATEPART(dw, @b1)='' then 'Fri'
else 'Sat'
END,
DATEName (wk, @b1),--week of year 15
DATEName (dy, @b1),--day of year 16
CASE --SemiYearly 17
when DATEPART(month, @b1)<=6 then N'上半年'
else N'下半年'
END,
CASE --Period of Ten Days 18
when DATEName (dd, @b1)<=10 then N'上旬'
when DATEName (dd, @b1)>20 then N'下旬'
else N'中旬'
END,
CASE --Period of Ten Days 19
when DATEName (dd, @b1)<=10 then N''
when DATEName (dd, @b1)>20 then N''
else N''
END,
CASE --Is it Weekend? 20
when DATEPART(dw, @b1)='' then '周末'
when DATEPART(dw, @b1)='' then '周末'
else '平时'
END
)
--日期加1天
set @b1=DATEADD(day, 1, @b1)
END
end

2、在数据库中构建这样的维度表之后,在SSAS出新建维度,这里就不再多说了。

重点介绍如何构建一个标准的时间维度,首先,打开维度设计选项卡,添加下面两套成员用来构建标准时间维度,按照图中的样子:

3、设置属性:

3.1 将Dim Date的属性“TYPE”设置为:Time

3.2 将带有“层级”的成员属性设置为:以“Day-层级”为例:Type =Days; KeyColumms ='内容见“键列”图',这里选择了组合键(确保在层级中“Day”是唯一的);所以需要设置NameColumns,将NameColumns='Day'用来显示成员而已。

3.3 带有层级的其他成员都按照3.2的设置,具体有不同:Year-层级的Type='Years' ,Month-层级的Type='Months' ,Quater-层级的Type='Quaters';当然还要选择NameColumn的相应字段用来显示。KeyColumns的组合字段的选择,只要符合保证唯一即可,例如Month的KeyColumns:

3.4 按照以上步骤,设置好之后,还是不行的,还需要将属性关系设置合理才行,按照下图的属性关系设置即可;设置成员的属性的时候,最好将成员的order by属性设置为“Key”,这样浏览的数据就会按照key排序了;除了带有层级的成员属性外,其他属性可以不需要额外设置即可;

3.5  这样处理维度,浏览查看效果:

SSAS-时间维度的标准设计的更多相关文章

  1. 《BI项目笔记》创建时间维度(1)

    SSAS Date 维度基本上在所有的 Cube 设计过程中都存在,很难见到没有时间维度的 OLAP 数据库.但是根据不同的项目需求, Date 维度的设计可能不大相同,所以在设计时间维度的时候需要搞 ...

  2. 《BI项目笔记》创建时间维度(2)

    创建步骤:   序号 选择的属性 重命名后的名称 属性类别 1 DateKey DateKey 常规 2 Month Key Month Key 月份 3 English Month Name Eng ...

  3. DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension)

    跟大家的交流是我的动力. :) DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★ ...

  4. MySQL学习笔记:生成时间维度表

    # ---- 对应时间戳怎么生成的? ---- /*TIME_CD TIME_CD1000000 000005000001 000005000002 000005000003 000005000004 ...

  5. 【BIEE】15_时间维度建立

    时间维度的建立 1.环境准备 ①新建时间维度表:TIME_DIMENSION 建立时间维度表并插入数据 ---------------创建时间维度表 create table TIME_DIMENSI ...

  6. DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension)

    DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★★★★★(5星) 这个时间系列想 ...

  7. 微软BI 之SSAS 系列 - 维度的优化,灌木丛属性关系,以及自然层次结构与非自然层次结构的概念

    维度的优化 在 SSAS 开发设计过程中,维度的优化非常重要,因为它在 SSAS 分析服务性能调优的过程中往往能起到一个非常重要的作用. 一般来说,对于 Cube 的性能优化第一步可能考虑的就是查看维 ...

  8. SSAS的维度表之间的关系只能有一个不能有多个

    我们在SSAS中创建维度的时候,有时候可能一个维度需要用到多个表的字段作为维度属性,那么这多个表之间势必存在关联关系,但是切记维度表之间的关联关系有且只能有一个不能有多个,下面我们来看一个例子. 现在 ...

  9. SSAS Cube 维度成员关系Rigid 和 Flexible

    维度成员关系指示成员关系是否随时间而更改.  值为 Rigid 和 Flexible,前者表示成员之间的关系不随时间而更改,后者表示成员之间的关系随时间而更改. 默认值为 Flexible.  指定适 ...

随机推荐

  1. Django auth 登陆后页面跳转至/account/profile,修改跳转至其他页面

    这几天在学习django,django功能很强大,自带的auth,基本可以满足用户注册登陆登出,简单的用户注册登陆系统使用django auth足矣.当然也不是拿来就能用的,需要自己写登陆页面的模板, ...

  2. [转]让Sublime Text2支持浏览器中预览

    转自http://www.imququ.com/post/view-sublime-text-2-file-in-browser.html 1.点击菜单Tools -> New Plugin.. ...

  3. Weblogic缓存

    缓存:如果脱离IDE工具的话,weblogic的文件会在\user_projects\domains\base_domain\servers\AdminServer\tmp\_WL_user文件夹中 ...

  4. Linux系统编程(22)——响应信号

    进程对信号的响应 进程可以通过三种方式来响应一个信号: 1.忽略信号,即对信号不做任何处理,其中,有两个信号不能忽略:SIGKILL及SIGSTOP: 2.捕捉信号.定义信号处理函数,当信号发生时,执 ...

  5. HTML5 Canvas动画效果演示 - 流浪的鱼 - 博客频道 - CSDN.NET

    HTML5 Canvas动画效果演示 - 流浪的鱼 - 博客频道 - CSDN.NET HTML5 Canvas动画效果演示

  6. #include<string.h>

    #include<string.h> 1 strcpy #include <string.h> char *strcpy(char *str1, const char *str ...

  7. UML图总结

    UML叙述 UML文档仅仅是设计与开发人员采用UML语言进行系统分析与设计的结果,并没有给出如何进行开发和采用何种开发流程,同样也不指导如何进行面向对象设计. UML文档描述了面向对象分析与设计的结果 ...

  8. DOS窗口中文显示乱码

    记得以前的dos是可以显示中文的,但是今天复制东西发现竟然不能显示中文了,遇见中文就成了? 在右键->默认值中的默认代码页也显示有中文GBK,但是不管用 在右键->属性中的当前代码页显示为 ...

  9. windows下启动/关闭Sybase数据库服务器

    启动.关闭Sybase数据库服务器 一.启动Sybase服务器 在windows下介绍两种方法启动Sybase数据库服务器. 1.通过服务器管理器 依次打开控制面板>管理工具>服务 管理窗 ...

  10. DropDownList 绑定数据后 插入一条不属于表中的数据

    ddlFGiftId.DataSource = dtGift; ddlFGiftId.DataTextField = "FGiftName"; ddlFGiftId.DataVal ...