《数据仓库的设计与开发.ppt》由会员分享,可在线阅读,更多相关《数据仓库的设计与开发.ppt(93页珍藏版)》请在三一办公上搜索。
1、第4章 数据仓库的设计与开发,2,4.1 数据仓库分析与设计4.2 数据仓库开发4.3 数据仓库技术与开发的困难,3,4.1数据仓库分析与设计,4.1.1 需求分析概念模型设计逻辑模型设计物理模型设计4.1.5 数据仓库的索引技术,4,4.1.1 需求分析,1.确定主题域2.支持决策的数据来源3.数据仓库的成功标准和关键性能指标4.数据量与更新频率,5,1.确定主题域,(1)明确对于决策分析最有价值的主题领域有哪些?(2)每个主题域的商业维度是哪些?每个维度的粒度层次有哪些?(3)制定决策的商业分区是什么?(4)不同地区需要哪些信息来制定决策?(5)对哪个区域提供特定的商品和服务?,6,2.支
2、持决策的数据来源,(1)哪些源数据(操作型)与商品主题有关?(2)在已有报表和在线查询中得到什么样的信息?(3)提供决策支持的细节程度是怎样的?,7,3.数据仓库的成功标准和关键性能指标,(1)衡量数据仓库成功的标准是什么?(2)哪些关键的性能指标?如何监控?(3)对数据仓库的期望是什么?(4)对数据仓库的预期用途有哪些?(5)对计划中的数据仓库的考虑要点是什么?,8,4.数据量与更新频率,(1)数据仓库的总数据量有多少?(2)决策支持所需的数据更新频率是多少?时间间隔是多长?(3)每种决策分析与不同时间的标准对比如何?(4)数据仓库中的信息需求的时间界限是什么?,9,通过需求分析,需要的数据
3、包括:,1.数据源(1)可用的数据源(2)数据源的数据结构(3)数据源的位置(4)数据源的计算机环境(5)数据抽取过程(6)可用的历史数据,10,2.数据转换数据仓库中的数据是为决策分析服务,而源系统的数据为业务处理服务。需要决定如何正确地将这些源数据转换成适合数据仓库存储的数据。,11,3.数据存储数据仓库所需要的数据的详细程度,包括足够的关于存储需求的信息,估计数据仓库需要多少历史和存档数据。,12,4.决策分析(1)向下层钻取分析(2)向上层钻取分析(3)横向钻取分析(4)切片分析(5)特别查询报表,13,4.1.2 概念模型设计,概念模型的特点是:(1)能真实反映现实世界,能满足用户对
4、数据的分析,达到决策支持的要求,它是现实世界的一个真实模型。(2)易于理解,便利和用户交换意见,在用户的参与下,能有效地完成对数据仓库的成功设计。(3)易于更改,当用户需求发生变化时,容易对概念模型修改和扩充。(4)易于向数据仓库的数据模型(星型模型)转换。,14,概念模型最常用的表示方法是实体关系法(E-R法)。E-R图描述的是实体以及实体之间的联系:用长方形表示实体,在数据仓库中就表示主题,椭圆形表示主题的属性,并用无向边把主题与其属性连接起来;用菱形表示主题之间的联系,用无向边把菱形分别与有关的主题连接。若主题之间的联系也具有属性,则把属性和菱形也用无向边连接上。,15,例子,有两个主题
5、:商品和客户,主题也是实体。商品有如下属性组:商品的固有信息(商品号、商品名、类别、价格等);商品库存信息(商品号、库房号、库存量、日期等);商品销售信息(商品号、客户号、销售量等);客户有如下属性组:客户固有信息(客户号、客户名、住址、电话等);客户购物信息(客户号、商品号、售价、购买量等)。商品的销售信息与用户的购物信息是一致的,它们是两个主题之间的联系。,16,商品,商品固有信息,商品号,商品库存信息,销售信息,购物信息,客户,客户固有信息,客户号,=,17,逻辑模型设计,主要工作为:(1)主题域进行概念模型(ER图)到逻辑模型(星型模型)的转换(2)粒度层次划分(3)关系模式定义(4)
6、定义记录系统,18,1、主题域进行概念模型到逻辑模型的转换,星型模型的设计步骤如下:(1)确定决策分析需求决策需求是建立多维数据模型的依据。(2)从需求中识别出事实选择或设计反映决策主题业务的表,如在“商品”主题中,以“销售业务”作为事实表。(3)确定维确定影响事实的各种因素,对销售业务的维包括商店,地区,部门,城市,时间,商品等,如图4.2所示。,19,图4.2 销售业务的多维数据,(4)确定数据汇总水平 数据仓库中对数据不同粒度的集成和综合,形成了多层次、多种知识的数据结构。例如,对于时间维,可以以“年”、“月”或者“日”等不同水平进行汇总。,(5)设计事实表和维表 设计事实表和维表的具体
7、属性。在事实表中应该记录哪些属性是由维表的数量决定的。一般来说,与事实表相关的维表的数量应该适中,太少的维表会影响查询的质量,用户得不到需要的数据,太多的维表又会影响查询的速度。,(6)按使用的DBMS和分析用户工具,证实设计方案的有效性 根据系统使用的DBMS,确定事实表和维表的具体实现。由于不同的DBMS对数据存储有不同的要求,因此设计方案是否有效还要放在DBMS中进行检验,(7)随着需求变化修改设计方案 随着应用需求的变化,整个数据仓库的数据模式也可能会发生变化。因此在设计之初,充分考虑数据模型的可修改性可以节省系统维护的代价。,22,从的ER图转换成星型模型实例说明,(1)业务数据的E
8、-R图,23,(2)E-R图向多维表的转换该问题的多维表模型中,商品维包括部门、商品和商品大类,地点维包括地区和商店,忽略存货,而只注意销售事实。在E-R图中不出现的时间,在多维模型中增加时间维。在多维模型中,实体与维之间建立映射关系,联系多个实体的实体就成为事实,此处销售实体作为事实,其他实体作为维。然后用维关键字将它转换为星型模型,如图4.5所示。,24,图4.4 E-R图向多维模型的转换,图4.5 利用维关键字制定的星型模型,26,在各维中,只有部门,商品类,地区,商店的编号没有具体的说明。为了打印报表将增加这些编号的名称说明,即部门名、商店名等,在维表中增加这些说明,即修改该星型模型
9、如图4.6 所示。,图4.6 修改后的星型模型,28,2、粒度层次划分,所谓粒度是指数据仓库中数据单元的详细程度和级别。数据越详细,粒度越小,层次级别就越低;数据综合度越高,粒度越大,层次级别就越高。进行粒度划分,首先要确定所有在数据仓库中建立的表,然后估计每个表的大约行数。,29,3、关系模式定义,在概念模型设计时,我们就确定了数据仓库的基本主题,并对每个主题的公共码键、基本内容等做了描述。在这一步里,我们将要对选定的当前实施的主题进行模式划分,形成多个表,并确定各个表的关系模式。,30,“商品”主题,公共码键:商品号。商品固有信息:商品表(商品号、商品名、类型、颜色)细节级商品销售信息:销
10、售表1(商品号、客户号、销售量、)细节级销售表2(商品号、时间段1、销售量、)综合级 销售表n(商品号、时间段n、销售量、)综合级,31,4、定义记录系统,定义记录系统是建立数据仓库中的数据以源系统中的数据的对照记录。记录系统的定义要记入数据仓库的元数据。商品主题的记录系统在元数据中可描述如 表4.2所示。,32,表4.2 记录系统的定义,33,4.1.4 物理模型设计,确定一个最适合应用要求的物理结构(包括存储结构和存取方法)。(1)估计存储容量(2)确定数据的存储计划(3)确定索引策略(4)确定数据存放位置(5)确定存储分配,34,1.估计存储容量,(1)对每一个数据库表确定数据量(2)对
11、所有的表确定索引(3)估计临时存储,35,2.确定数据的存储计划,(1)建立聚集(汇总)计划(2)确定数据分区方案(3)建立聚类选项,36,3.确定索引策略,在数据仓库中由于数据量很大,需要对数据的存取路径进行仔细设计和选择,建立专用的复杂的索引,以获得最高的存取效率。采用BTree索引,它是一个高效的索引,见图4.7所示。B树是一个平衡(balance)树,即每个叶结点到根节点的路径长度相同。B树索引是一个多级索引。,37,4.确定数据存放位置,在物理设计时,我们常常要按数据的重要程度、使用频率以及对响应时间的要求进行分类,并将不同类的数据分别存储在不同的存储设备中。重要程度高、经常存取并对
12、响应时间要求高的数据就存放在高速存储设备上,如硬盘;存取频率低或对存取响应时间要求低的数据则可以放在低速存储设备上,如磁盘或磁带。,38,5.确定存储分配,物理存储中以文件、块和记录来实现。一个文件包括很多块,每个块包括若干条记录。文件中的块是数据库的数据和内存之间I/O传输的基本单位,在那里对数据进行操作。用一个简例来说明逻辑模型和物理模型的内容,见下图所示。,40,4.1.5 数据仓库的索引技术,1.位索引技术2.标识技术3.广义索引,41,1.位索引技术,(1)Bit-Wise索引技术(2)B-Tree技术与Bit-Wise索引技术对比,42,对于每一个记录的字段满足查询条件的真假值用“
13、1”或“0”的方式表示,或者用该字段中不同取值(即多位二进制)来表示。例如,检索“美国加州有多少男性未申请保险?”利用BitWise技术得到有两个记录 满足条件。,=2,44,(2)B-Tree技术与Bit-Wise索引技术对比,Bit-Wise索引技术比B-Tree技术能提高相应速度10100倍。对于检索“美国加州有多少男性未申请保险?”为例,假设数据库有10M记录,每个记录长800个字节,每一页16K字节。按传统的关系数据库的检索:需要经过50万次I/O操作。按BitWise检索:对于10M个记录建立三列的BitWise索引。存取这些索引只要进行235次I/O操作。,45,2.标识技术,姓
14、名 籍贯 职称 年龄陈文东 江西 教授 56何玉辉 河北 讲师 32李宝 湖南 副教授 37施东 江苏 讲师 28曹文 湖南 副教授 36赵玉 吉林 讲师 32黄小斌 江苏 讲师 28赛英花 山东 副教授 32彭宏 江西 讲师 25廖宇宙 湖南 教授 42,样本记录:,46,数据库中的每个实体创建一个标识。“江西”在籍贯中是01标识。“28”在年龄中是02标识。“讲师”在职称名中有一个03标识。上面的数据库可以被减化为一系列标识,如下面所示:,47,姓名 籍贯 职称 年龄陈文东 01 江西 01 教授 01 25 01何玉辉 02 河北 02 副教授 02 28 02李宝 03 湖南 03 讲
15、师 03 32 03施东 04 江苏 04 36 04曹文 05 吉林 05 37 05赵玉 06 山东 06 42 06黄小斌 07 56 07赛英花 08 彭宏 09 廖宇宙 10,48,数据库被精简如下:,记录1 01,01,01,07记录2 02,02,03,03记录3 03,03,02,05记录4 04,04,03,02记录5 05,03,02,05记录6 06,05,03,03记录7 07,04,03,02记录8 08,06,02,03记录9 09,01,03,01,49,3.广义索引,对数据仓库的一个很广泛的应用问题是“这个月销售最好和最差的10种商品是哪些?”,我们可以设计这么
16、一块“黑板”,在上面标明了当月销售最好和最差的10种商品的名称或者它们相关记录的存放地址。这块“黑板”就是我们所说的“广义索引”。,50,4.2 数据仓库开发4.3 数据仓库技术与开发的困难,51,4.2 数据仓库开发,数据仓库开发过程4.2.2 数据质量与数据清洗4.2.3 数据粒度与维度建模,52,数据仓库开发过程,4.2.2.1 分析与设计阶段 4.2.1.2 数据获取阶段4.2.1.3 决策支持阶段4.2.1.4 维护与评估阶段,需求分析,数据装载,信息查询,概念设计,逻辑设计,物理设计,数据抽取,数据转换,知识探索,数据仓库增长,数据仓库维护,数据仓库评估,数据仓库开发过程,54,分
17、析与设计阶段,1.需求分析2.概念设计3.逻辑设计4.物理设计,55,1.需求分析,确定决策主题域分析主题域的商业维度分析支持决策的数据来源确定数据仓库的数据量大小分析数据更新的频率确定决策分析方法,56,2.概念设计,建立概念模型:对每个决策主题与属性以及主题之间的关系用E-R图模型表示。E-R图将现实世界表示成信息世界,便利向计算机的表示形式进行转化。,57,3.逻辑设计,将概念模型(E-R图)转换成逻辑模型,即计算机表示的数据模型。数据仓库数据模型一般采用星型模型。星型模型由事实表、维表组成。,58,4.物理设计,对逻辑模型设计的数据模型确定物理存储结构和存取方法。数据仓库的星型模型在计
18、算机中仍用关系型数据库存储。物理设计还需要进行存储容量的估计;确定数据存储的计划;确定索引策略;确定数据存放位置以及确定存储分配。,59,4.2.1.2 数据获取阶段,1.数据抽取2.数据转换3.数据装载,60,1.数据抽取,对数据源的确认,确定数据抽取技术,确认数据抽取频率,按照时间要求抽取数据。由于源系统的差异性,如计算机平台、操作系统、数据库管理系统、网络协议等的不同造成了抽取数据的困难。,61,2.数据转换,数据格式的修正字段的解码单个字段的分离信息的合并变量单位的转化时间的转化数据汇总,62,3.数据装载,初始装载:第一次装入数据仓库。增量装载:根据定期应用需求装入数据仓 库。完全刷
19、新:完全删除现有数据,重新装入 新的数据。,63,4.2.1.3 决策支持阶段,1.信息查询2.知识探索,64,1.信息查询,信息查询者使用数据仓库能发现目前存在的问题。创建数据阵列 将相关的数据(每月的数据)放在同一个物理位置上。预连接表格 对于两个或多个表格共享一个公用链。,65,预聚集数据以每天为基础存储数据。在一周结束时,以每周为基础存储数据(即累加每天的数据)。月末时,则以每月为基础存储数据。聚类数据聚类将数据放置在同一地点,这样可以提高对聚类数据的查询。,66,2.知识探索,发现的问题并找出原因。创建一个单独的探索仓库,不影响数据仓库的常规用户。同时采用“标识技术”进行数据压缩,提
20、高数据分析速度。使用一些模型帮助决策分析,例如客户分段、欺诈监测、信用分险、客户生存期、渠道响应、推销响应等模型。通过模型的计算来得出一些有价值的商业知识。,67,采用数据挖掘工具来获取商业知识。例如,得到如下一些知识:哪些商品一起销售好?哪些商业事务处理可能带有欺诈性?高价值客户的共同点是什么?获取的知识为企业领导者提供决策支持,达到保留客户,减少欺诈,提高公司利润具有重要作用。,68,4.2.1.4 维护与评估阶段,1.数据仓库增长2.数据仓库维护3.数据仓库评估,69,1.数据仓库增长,数据仓库建立以后,随着用户的不断增加,时间的增长,用户查询需求更多,数据会迅速增长。在数据仓库的开发过
21、程中需要适应数据仓库不断增长的现实。,70,2.数据仓库维护,适应数据仓库增长的维护数据增长的处理工作有:去掉没有用的历史数据;根据用户使用的情况,取消某些细节数据和无用的汇总数据,增加些实用的汇总数据。,71,正常系统维护,数据仓库的备份和恢复。备份数据为系统恢复提供基础,一旦系统出现灾难时,利用备份数据可以很快将数据仓库恢复到正常状态。,72,3.数据仓库评估,(1)系统性能评定(2)投资回报分析(3)数据质量评估,73,(1)系统性能评定,硬件平台是否能够支持大数据量的工作和多类用户、多种工具的大量需求?软件平台是否是用一个高效的且优化的方式来组织和管理数据?是否适应系统(数据和处理)的
22、扩展?,74,(2)投资回报分析,定量分析:计算投资回报率(ROI),即收益与成本的比率。定性分析:企业与客户之间关系状态?对机会快速反应能力如何?改善管理能力如何?,75,(3)数据质量评估,数据是准确的。数据符合它的类型要求和取值要求。数据具有完整性和一致性。数据是清晰的且符合商业规则。数据保持时效性并不能出现异常。,76,4.2.2 数据质量与数据清洗,1.数据质量问题2.数据污染产生的原因3.数据清洗,77,1.数据质量问题,(1)字段中的虚假值。(2)数据值缺失。(3)不一致的值。(4)违反常规的不正确值。(5)一个字段有多种用途。(6)标法不唯一。,78,2.数据污染产生的原因,(
23、1)系统转换(2)数据老化(3)复杂的系统集成(4)数据输入的不完整信息(5)输入错误(6)欺诈(7)缺乏相关政策,79,3.数据清洗,只清洗那些重要的数据,而忽略那些不重要的数据。数据在被存储进数据仓库之前就应该进行清洗。找到适合源系统的字段和格式的清洗工具。建立数据质量领导小组;建立数据质量政策和标准;定义质量指标参数和基准;识别受坏数据影响最大的商业功能。对有较大影响力的数据元素定制清洗计划,并执行数据清洗。,80,4.2.3 数据粒度与维度建模,数据粒度是指数据仓库的数据中保存数据的细化程度或综合程度的级别。数据粒度深深影响存放在数据仓库中的数据量的大小,同时影响数据仓库所能回答的查询
24、类型。,81,1.大维度与雪花模型,在数据仓库中,客户维度和产品维度是典型的大维度。大维度表采用雪花模型的数据组织,是一种有效的方法。对产品维度,产品是分属于产品品牌,品牌又分属于产品分类。对客户维度,客户分属于地区,地区分属于国家。对于销售的雪花模型如图4.11所示。,图4.11 销售事实的雪花模型,83,2.综合事实表,大多数查询不是基于基础事实表上操作的,而是基于综合数据的查询。这样建立综合事实表是提高综合数据查询的非常有效的方法,且大大提高数据仓库的性能。在多维表中,很多维都是具有层次结构,对不同维的层次的提升,将可建立多种综合事实表。从图4.12可见,对基础事实表查询利用产品维表,对
25、综合事实表查询,利用产品分类维表。,销售事实表(基础表),图4.12 综合事实表和衍生维度(产品分类)表,85,4.3 数据仓库技术与开发的困难,数据仓库技术数据仓库开发的困难,86,数据仓库技术,1.管理大量数据对于数据仓库最重要的技术就是能够管理大量的数据。数据仓库要管理大量的数据,是因为它们:(1)包括粒状的、原子的细节(2)包括历史数据(3)包括细节和汇总数据(4)包括元数据有好多种管理大量数据的方法通过寻址,通过索引,通过数据的外延,通过有效的溢出管理等,87,2.数据的高效装入和数据压缩,数据仓库的一个重要的技术就是能够高效地装入数据。有好多种装入数据的方法:通过一个语言接口一次一
26、条记录。当数据能够被压缩时,它便能存储在很小的空间中。,88,3.存储介质的管理,存储介质 访问速度 存储费用,主存 非常快 非常贵扩展内存 非常快 贵高速缓存 非常快 贵磁盘 快 适中光盘 不慢 不贵微缩胶片 慢 便宜,考虑到访问速度和存储费用,对数据的存储要分层次,层次的区分如下:,89,7.多维DBMS和数据仓库,多维数据库管理系统(多维DBMS)使得对数据的访问非常灵活,可以用多种方法对数据进行切片、分割,动态地考察汇总数据和细节数据的关系。,90,数据仓库和多维DBMS的区别:(1)数据仓库有大量的数据;多维DBMS中的数据至少要少一个数量级。(2)数据仓库只适合于少量的灵活访问;而
27、多维DBMS适合大量的非预知的数据的访问和分析。(3)数据仓库内存储了很长时间范围内的数据从5年到10年;多维DBMS中存储着比较短时间范围内的数据。(4)数据仓库允许分析人员以受限的形式访问数据,而多维DBMS允许自由的访问。,91,决策支持系统(DSS)分析者大部分时间里可以在多维DBMS中享受其操作高效的优点,同时如果需要的话,还可以向下钻取最低层次的细节数据。一些多维DBMS建立在关系模型上,而一些多维DBMS建立在多维立方体内.,92,数据仓库开发的困难,1.没有理解数据的价值2.未能理解数据仓库概念3.尚未清楚了解用户将如何使用数据仓库之前,便贸然开发数据仓库4.对数据仓库规模的估计模糊5.忽视了数据仓库体系结构和数据仓库开发方法,第1部分结束,