数据库及数据仓库精要(PPT 52页)35929.pptx
《数据库及数据仓库精要(PPT 52页)35929.pptx》由会员分享,可在线阅读,更多相关《数据库及数据仓库精要(PPT 52页)35929.pptx(52页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数据库及数据仓库精要数据库及数据仓库精要终极目标:Ad-hoc报表系统Ad-hoc释义:即时的、随意的、特殊的前言前言n数据库扮演的角色 也叫联机事务处理OLAP(Online Transactional Processing),数据库保存由日常管理过程中涉及的业务操作创建的操作型结构化数据,数据记录系统管理行为(通过各种业务逻辑来交互)。反映细粒度的事务数据,保存时间短。主要依赖关系模式建模方法论。n数据仓库扮演的角色 也叫联机分析处理OLAP(Online Analytical Processing),数据由联机事务处理来,经过选择和聚集,变为统计分析事实产生的因果,辅助决策制定(通过各种
2、统计分析报表来交互)。反映大范围的事实数据(业务事件的累积),保存时间长。主要依赖多维模式建模方法论n主题、事实和事件(请注意语义)事实是一个主题,比如:销售、配送、住院、手术等。一个主题对应了多个相互关联的关系模式,也可以叫做相关关系表。事实的实例对应着发生的事件,比如:一个执行的销售、配送、住院、手术等都是一个事件。每个事实由一组提供了事件的量化描述的度量的属性值描述,比如:销售收入、配送量、住院支出、手术时间等n通过语义将数据库和数据仓库结合在一起从报表到报表存在的问题及对策纲领从报表到报表存在的问题及对策纲领n对策纲领n实体(关系所代表的实体)原子化,是指实体本身不能再分解n属性原子化
3、,是指实体的属性(值域所代表的属性)本身不能再分解n主键原子化,是指实体的主键本身是一个唯一的ID字段n联系原子化,是指实体间的联系(关系所代表的联系)都是一对多的联系n命题原子化,是指语义角度的联系原子化n现实(面对单一主题,数据规模极小,仅是面对招投标业务追踪)1)第二个表是从第一个表通过高级程序员编写VBA程序实现,第一个表也是专业定岗员工通过Excel专用表单维护和更新的,背后其实还是高级程序员的工作价值体现2)信息化岗位需求及配置:高级程序员四名,六个专业业务人员。满负荷工作以应对数据变动和操作功能变动n解决方案:报表列表化,去除冗余数据,建模信息化模型(数据库模型)并影射和实现为A
4、ccess桌面数据库应用问题的导入问题的导入-从从ExcelExcel表格出发引出的问题表格出发引出的问题结构良好的表,范式,SQL语言,关系模式及E-R图n基本表与中间表、临时表不同,基本表及其字段之间的关系,应尽量满足第三范式,是结构良好的表,它可以消除删除行,改变行,修改行(实例)的错误和异常。它具有如下四个特性:(1)原子性,基本表中的字段是不可再分解的。(2)原始性,基本表中的记录是原始数据(基础数据)的记录。(3)演绎性,由基本表与代码表中的数据,可以派生出所有的输出数据。(4)稳定性,基本表的结构是相对稳定的,表中的记录是要长期保存的。(5)基本表的每个决定因子都必须是候选建。(
5、6)非基本表必须分解为两个或多个基本表。n三个基本范式:(1)1NF是对属性的原子性约束,要求属性具有原子性,不可再分解。(2)2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性。(3)3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余n大多数结构不良好的表,会产生或包含大量的冗余数据,同时可能会出现删除行,改变行,修改行的错误和异常,这都是都是使用了SQL DML CURD语句产生的。像中间表、报表和临时表:(1)中间表是存放统计分析数据的表,它是为数据仓库、输出报表或查询结果而设计的,有时它没有主键与外键(数据仓库除外)。(2)临时表是程序员个人设
6、计的,存放临时记录,为个人所用。(3)基表和中间表由DBA维护,临时表由程序员自己用程序自动维护。n关系是一个由行和列组成的二维表,不一定结构良好,特征为:行包括实体的数据,列包含实体性质的数据,表中的单元格存储单个值,每列的所有实体类型一致,每列具有唯一名称,列的顺序任意,行的顺序任意,任意两行互不重复。这是最大的复合关系模式的条件,符合这个要求的表就是关系型表格。n通过E-R图将这些概念反映出来,通过名词性和动词性,完全可以描述客观世界,其中名词性描述实体,动词性描述联系或动作影响,通过动词性将不同的实体关联在一起第一目标或者叫基础目标:统计,汇总及分析报表的工作尽量地自动用Excel或S
7、preadsheet做,几乎不需人为干预目录目录nE-R模型的概念与表示n实体-联系方法(概念模型及设计,关注现实世界)n关系模式的规范化(消除数据冗余,避免操作异常)nE-R图向关系表(Schema)的转换(逻辑模型及设计,关注信息世界)n多维模式与统计分析的关系nExcel或Spreadsheet在统计分析中的角色n统计分析系统(多维模式建构)的演进n终极目标:Ad-hoc报表系统关于现实世界事实及描述的定义关于现实世界事实及描述的定义n事实包括以下四个方面:第一:事实是指“某物具有某种性质或某些事物具有某种关系。”与原子命题、分子命题的分类相对应,事实可以分为原子事实、分子事实。其中,原
8、子事实是最基本、最简单的事实,从中不能再析出其它事实;分子事实是原子事实的复合 第二:事实具有客观性。“大多数的事实的存在都不依靠我们的意愿;这就是为什么我们把它们叫作严峻的、不肯迁就的或不可抗拒的理由。大部分物理事实的存在不仅不依靠我们的意愿,而且也不依靠我们的存在”第三:现实世界由各种各样的事实组合而成,事实属于现实世界 第四:事实决定命题的真伪,“事实是使得命题为真或为假的东西”。具体说来,原子命题的真假取决于它是否与原子事实相符合,分子命题的真假取决于组成它的原子命题的真假n现实世界的语义描述的存在 第一:原子命题 第二:分子命题 第三:段落(由多个逻辑紧密相关的分子命题构成)第四:主
9、题(由多个逻辑紧密相关的段落构成)E-RE-R模型的概念与表示模型的概念与表示nE-R图也称实体-联系图(Entity Relationship Diagram),提供了表示实体类型、实体属性和相关实体之间联系(三个要素)的方法,用来描述现实世界的概念模型n关系数据库使用实体-联系模型(E-R模型)进行数据库设计,以构造信息世界的逻辑模型。E-R数据库设计工具提供了一个“方框与箭头”的绘图工具,帮助数据库用户建立E-R图来描绘数据,逻辑及现实世界nE-R图可以手绘,亦可以借用Case工具(Power Designer,Visio或SQL Power Architect)做出n考察单独的一个联系
10、(动词类型的语义连接及构造能力),联系及相互关联的实体形成的一个描述,构造了一个最基本的原子命题E-RE-R模型的概念与表示模型的概念与表示实体集-语义(名词类性)n实体(Entity)n事物就是在行动影响下物质本身的改变,或者进行。客观存在并可相互区别的事物称为实体。实体可以是具体的,也可以是抽象的概念或联系。n具有共性的一类实体可归类为一个实体集(Entity set)。n属性(Attribute)n实体所具有的某一特性称为属性。n一个实体可以由若干个属性来刻画。n域(Domain)n属性的取值范围或类型。n键或标识符(Key)n标识符是实体中一个或多个属性的集合,可用来唯一标识实体中的一
11、个实例。每个实体都必须至少有一个标识符。如果实体只有一个标识符,则它为实体的主标识符。如果实体有多个标识符,则其中一个被指定为主标识符,其余的标识符就是次标识符(候选标识符)E-RE-R模型的概念与表示模型的概念与表示联系集-语义(动词类型)n实体之间可以通过联系来相互关联。与实体和实体集对应,联系也可以分为联系和联系集,联系集是实体集之间的联系,联系是实体之间的联系,联系是具有方向性的。n联系具有方向性,每个方向上都有一个基数。n联系的两个方向上各自包含有一角色名,描述该方向联系的作用。n按照实体类型中实例之间的数量对应关系,通常可将联系分为4个基本联系分为类,即一对一(ONETO ONE)
12、联系、一对多(ONE TO MANY)联系、多对一(MANY TO ONE)联系和多对多联系(MANY TO MANY)。n三个特殊联系n每个实体类型都有自己的标识符,如果两个实体集之间发生联系,其中一个实体类型的标识符进入另一个实体类型并与该实体类型中的标识符共同组成其标识符时,这种联系则称为标定联系,也叫依赖联系。反之称为非标定联系,也叫非依赖联系。n递归联系是实体集内部实例之间的一种联系,通常形象地称为自反联系。同一实体类型中不同实体集之间的联系也称为递归联系。E-RE-R模型的概念与表示(使用模型的概念与表示(使用CaseCase工具时的图符及事例)工具时的图符及事例)E-RE-R模型
13、的概念与表示模型的概念与表示E-R图的设计步骤 n第一步:针对特定的应用,确定实体、属性和实体间的联系,画出局部E-R图。n第二步:综合各个局部E-R图,产生反映数据库整体概念的总体E-R图。E-RE-R模型的概念与表示(手绘草图事例)模型的概念与表示(手绘草图事例)弱实体集n有些实体集的所有属性都不足以形成主码,这样的实体集称为弱实体集(Weak Entity Set),依赖于其它实体集而存在。n与此相对,其属性可以形成主码的实体集称为强实体集。n弱实体集所依赖的实体集称为标识实体集(identifying entity set),相应的关系为标识联系(identifying relatio
14、nship)。OrderItemdatestatuspaymentorder#item#tagIncludeE-RE-R模型的概念与表示模型的概念与表示n弱实体集通常没有主键。n以订单的分项为例,订单项实体集可能有编号(局部的编号)、商品名称、数量、单价等属性,但是这些属性不足以识别一个定单项,因为完全有可能在另外一张订单中出现相同的内容。n必须把订单的关键字(如一个全局的订单编号)和定单项的局部编号结合起来才能标示一个定单项。n弱实体集的属性中,用来与标识实体集的键结合以识别一个弱实体集的属性称为部分键(partial key)。n弱实体集的主键=它的标识实体集的键+它的部分键E-RE-R模
15、型的概念与表示(手绘草图事例)模型的概念与表示(手绘草图事例)nE-R图使用双线矩形表示弱实体集,弱实体集与其标识实体集之间的联系用双线菱形表示,弱实体集的部分键使用虚下划线表示。OrderItemdatestatuspaymentorder#item#tagIncludeE-RE-R模型的概念与表示模型的概念与表示n实体集的层次关系n现实世界中的很多概念之间都具体层次关系。nE-R模型使用实体集间的继承和ISA关系来描述这种概念间的层次关系n实体集老师或学生都继承自实体集人,并且实体集老师或学生与实体集人之间都满足ISA关系,即老师或学生都是人的一种。nISA关系可以从两个方向进行设计n从自
16、上而下的方向,首先设计出人这一实体,然后根据属性的不同,将两种不同的人具体化(specification)为老师或者学生。n从自下而上的方向,首先设计出老师或学生,然后将他们的共性提取出来,泛化(generalization)为人。E-RE-R模型的概念与表示模型的概念与表示n层次关系的约束n从子实体集之间是否相交角度,不相交(disjoin)泛化要求继承自同一父辈的多个子实体集之没有交集,重叠(overlapping)泛化则允许有交集。n从泛化是否完全角度,全参与泛化要求所有父辈实体都必须同时也是某一子辈实体,部分泛化则允许不是任何子辈实体的父辈实体存在。n例如,在采用会员制的销售系统中,顾
17、客被分为会员(VIP)与非会员(NONVIP)两种,会员拥有消费积分(credit),非会员拥有固定的折扣率(discount)。一个顾客要么是会员、要么是非会员,二者必取其一,因此为全参与不相交。E-RE-R模型的概念与表示(手绘草图事例)模型的概念与表示(手绘草图事例)CustomerISAVIPNONVIPcreditdiscountdisjoincustomer#namegenderbirthdaycityaddressemailE-RE-R图符(手绘草图事例)图符(手绘草图事例)实体实体-联系方法联系方法实体还是属性n凡是满足以下两条准则的事物,一般均可作为属性对待。n作为属性,不能
18、再具有需要描述的性质。属性必须是不可分的数据项,不能包含其他属性。n属性不能与其他实体具有联系,即E-R图中所表示的联系是实体之间的联系。n例如书籍是一个实体,书号、书名、作者、出版社、定价是书籍的属性,如果应用系统不再需要作者的其他信息,如电话、住址、个人主页等,那么根据原则1可以将作者作为书籍的属性对待。但是如果这些信息是必须的,那么作者作为一个实体看待更为恰当。实体实体-联系方法(手绘草图事例)联系方法(手绘草图事例)bookisbntitlepricepresswritten_bynameauthorauthorcityserialbookisbntitlepricepressauth
19、or实体实体-联系方法联系方法实体还是联系n一般来说,实体对应现实世界中实际存在的事物,是名词类型;联系对应的概念一般是一种动作,是动词类型。n例如:n书和作者都是现实世界中的名词,因此作为实体。n而written_by表示作者写书这一动作,因此作为联系。n映射基数往往影响到一个概念是作为实体还是联系的选择。n若一项贷款只能由一个分行发放,并且只能由一个客户借贷,则将Loan作为Customer与Branch之间的联系比较合适。n但如果允许多个客户共同借贷同一项贷款,在这种情况下,将Loan作为实体。实体实体-联系方法(手绘草图事例)联系方法(手绘草图事例)二元关系还是多元关系n数据库中使用得
20、最多的是二元联系。n通常,将多元关系转换为二元关系。n如学校选课系统,涉及到学生、教室、教师、课程等多个实体,可表示为一个四元关系。学生学生上课上课教室教室教师教师课程课程学生学生选课选课课程课程授课授课教师教师地点地点教室教室实体实体-联系方法(手绘草图事例)联系方法(手绘草图事例)n但也有一些情况下使用多元联系更好(如需要表达多个实体集间的约束时)n如学校选课系统中若一门课程可由多个教师教授,并且若课程和教师确定,则上课的地点也随之确定。实体实体-联系方法(手绘草图事例)联系方法(手绘草图事例)联系属性的放置n影响联系属性放置的主要因素是联系的映射基数。n对于一对一或一对多联系,选择作为联
21、系属性或实体属性只是体现语义侧重点的不同 n如销售系统需要记录顾客(Customer)与订单(Order)之间的关系(Possess)。由于一个订单只能由一个顾客所有,因此为顾客与订单之间为一对多关系。这时,记录生成订单日期的属性(date)既可以作为联系Possess的属性,也可作为订单的属性。OrderdatestatuspaymentorderPossesCustomer实体实体-联系方法(手绘草图事例)联系方法(手绘草图事例)n对于多对多联系,联系的属性不能作为实体的属性。n如,顾客与希望书籍之间的联系希望购买(Wish_for)。nWish_for有一属性date,表示顾客发出购买意
22、向的日期,这一属性不能作为参与联系的两个实体Customer或Book的属性。BookWish_forCustomerdate实例实例在线书店数据库在线书店数据库n类似于Amazon的在线书店系统所用的数据库n数据库中要求存储所有书籍的相关信息,并对书加以分类;n顾客的有关信息也要求存储在数据库中,并且允许用户选择自己感兴趣的书籍类别及希望购买的图书;n顾客在决定购买时可以发出订单,同一订单可以包含多种书,每种书可一次购买多本。顾客在订单中提供送货地址,系统根据订单发货。实例在线书店数据库E-R图(手绘草图事例)实例实例在线书店数据库在线书店数据库n合并分E-R图n各分E-R图之间的冲突主要有
23、三类:n属性冲突(1)属性域冲突,即属性值的类型、取值范围或取值集合不同。例如:属性“订单号”有的定义为字符型,有的为数值型。(2)属性取值单位冲突。例如:属性“库存”有的以册为单位,有的以千册为单位。n命名冲突 (1)同名异义。不同意义对象相同名称。例如:Author和Customer均有属性name。(2)异名同义(一义多名)。同意义对象不相同名称。例如:“项目”和“课题”。实例实例在线书店数据库在线书店数据库n结构冲突 (1)同一对象在不同应用中具有不同的抽象。例如:“作者”在某一局部应用中被当作实体,而在另一局部应用中则被当作属性。(2)同一实体在不同局部视图中所包含的属性不完全相同,
24、或者属性的排列次序不完全相同。(3)实体之间的联系在不同局部视图中呈现不同的类型。例如:实体E1与E2在局部应用A中是多对多联系,而在局部应用B中是一对多联系;又如在局部应用X中E1与E2发生联系,而在局部应用Y中E1、E2、E3三者之间有联系。n解决方法是根据应用的语义对实体联系的类型进行综合或调整。关系模式关系模式n设计范式(范式,数据库设计范式,数据库关系表的设计范式)是符合某一种级别的关系模式的集合。构造数据库必须遵循一定的规则。在关系数据库中,这种规则或者叫约束就是范式。关系数据库中的关系必须满足一定的要求,即满足不同的范式n第一范式(1NF):在任何一个关系数据库中,第一范式(1N
25、F)是对关系模式的基本要求,不满足第一范式(1NF)的数据库就不是关系数据库。所谓第一范式(1NF)是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有重复的属性。如果出现,就可能需要定义一个新的实体,新实体与原实体之间为一对多关系n第二范式(2NF):数据库表中不存在非关键字段对任一候选关键字段的部分函数依赖(部分函数依赖指的是存在组合关键字中的某些字段决定非关键字段的情况),也即所有非关键字段都完全依赖于任意一组候选关键字。如果存在,那么这个属性和主关键字的这一部分应该分离出来形成一个新的实体,新实体与原实体之间是一对多的关系n第三范
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库及数据仓库精要PPT 52页35929 数据库 数据仓库 精要 PPT 52 35929
限制150内