- 1、本文档共38页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
6_第7占奥 数据库设计和E-R模型1
第七章 数据库设计和E-R 模型第七章 数据库设计和E-R 模型设计过程实体-联系模型约束设计问题 扩展的E-R特性银行数据库的设计转换为关系模式数据库设计UML7.1 设计过程设计阶段:概念设计阶段逻辑设计阶段物理设计阶段 设计问题:冗余不完整实体-联系模型实体-联系(Entity-Relationship)模型:E-R模型是一种语义模型。 在将现实世界事实的含义和相互关联映射到概念模式方面非常有用。采用三个基本概念:实体集、联系集、属性一个数据库可以被建模为:实体的集合实体间的联系实体集实体是现实世界可区别于所有其他对象的一个“事物”或“对象”。例子:张三,公司,事件,计划实体集是相同类型即具有相同性质(或属性)的一个实体集合。例子:所有人的集合,公司的集合,树的集合,假日的集合实体集的外延是指属于实体集的实体的实际集合。实体有属性,它是实体集中每个成员所拥有的描述性性质。例子:人有姓名和地址 每个实体的每个属性都有一个值。实体集instructor 和 studentinstructor_ID instructor_name student-ID student_name联系集联系是指多个实体间的相互关联 例子: 44553 (Peltier) advisor 22222 (Einstein) student entity relationship set instructor entity联系集是相同类型联系的集合 (44553,22222) ? advisor联系集Advisor联系集(续)联系集也可以有属性。比如,实体集instructor 和 student 之间的联系集advisor,可以有属性date,以表示教师成为学生的导师的日期联系集中实体的角色实体在联系中扮演的功能称为实体的角色角色是隐含的,通常不指定当同样的实体集参与一个联系集多于一次,这类联系集称作是自环的。此时需用角色指明实体是如何参与联系实例的联系集的度参与联系集的实体集的数目称为联系集的度。二元联系集涉及两个实体集 (度为2)。数据库系统中大多数联系集都是二元的。涉及两个实体集以上的联系是很少的。students 在instructor的指导下完成projects 。 proj_guide 是instructor, student和project之间的三元联系。属性实体通过一组属性来表示,属性是实体集中每个成员所拥有的描述性性质 instructor = (ID, name, street, city, salary ) course= (course_id, title, credits)域–每个属性可取值的集合,也称值域实体集的属性是将实体集映射到域的函数 属性类型:简单和复合属性单值和多值属性举例: 多值属性: phone_numbers派生属性和基属性派生属性可以从别的属性派生出来。派生属性值不存储,而是在需要时计算出来。复合属性映射基数约束映射基数,或基数比率,表示一个实体通过一个联系集能关联的实体的个数。在描述二元联系集时非常有用对二元联系集来说,映射基数必然是以下情况之一:一对一一对多多对一多对多 映射基数一对多一对一注意:A和B中的某些元素可能并不映射到另一集合中的任一元素映射基数多对一多对多注意:A和B中的某些元素可能并不映射到另一集合中的任一元素参与约束如果实体集E中的每个实体都参与到联系集R的至少一个联系中,实体集E在联系集R中的参与称为全部(total)的。如果实体集E中只有部分实体参与到R的联系中,实体集E在联系集R中的参与称为部分(partial)的。码一个实体集的超码是一个或多个可以用来唯一地标识实体的属性。一个实体集的候选码是最小的超码ID 是instructor的候选码course_id是course的候选码主码是被选择用来区分实体的候选码,主码只有一个,但候选码可以有多个。联系集的码如果联系集R没有属性与之相关联,那么属性集合 primary-key(E1)∪primary-key(E2)∪…∪primary-key(En) 描述了集合R 中的一个联系。 如果联系集R有属性a1,a2, …, am 与之相关联,那么属性集合 primary-key(E1)∪primary-key(E2)∪…∪primary-key(En) ∪{a1,a2, …, am } 描述了集合R中的一个联系。相关的实体集的主码的集合形成了联系集的超码。 在以上的两种情况下,属性集合 primary-key(E1)∪primary-key(E2)∪…∪primary-key(En) 总是构成联系集的一个超码。 联系集的码(s_id, i_id) 是ad
文档评论(0)