第17章 关系数据库基本理论 计算机软件技术基础教程 教学课件.ppt

第17章 关系数据库基本理论 计算机软件技术基础教程 教学课件.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第17章 关系数据库基本理论 17.2 关 系 运 算 17.3 关系数据库语言 17.4 关系模式规范化 EXEC SQL END DECLARE SECTION; EXEC SQL INCLUDE SQLCA; main ( ) { printf(Input users name:); scanf (%s, user.arr); user.len=strlen(user.arr); printf(\nInput users password:); scanf(%s, pwd.arr); pwd.len=strlen(pwd,arr); EXEC SQL CONNECT : user IDENTIFIED BY: pwd; printf(connected user:%s to system \n, user.arr); while (SQLCODE=0) { EXEC SQL DECLARE C1 CURSOR FOR SELECT C#,G FROM SC WHERE S#=19205 FOR UPDATE OF S#; EXEC SQL OPEN C1; EXEC SQL FETCH C1 INTO: cno,: grade; EXEC SQL UPDATE SC SET S#=19301 WHERE CURRENT OF C1; printf(\n (#=%s, G=%s, cno, grade); EXEC SQL COMMIT WORK; } } 程序说明部分的VARCHAR是SQL提供的变字长字符串类型。VARCHAR user[10] 等价于 struct { usigned short int len; usigned char arr[20] } user 在构造反映现实世界的E-R模型时,我们重点考虑的是实体及实体之间的联系,而实体中的各个属性之间的联系并未涉及。事实上, 实体中的各个属性之间的联系是客观事物中最为重要的一种特性。 在关系数据库中,实体及实体内的各属性的联系通过关系模式来描述。一个关系数据库可包含多个不同的关系模式,而全部关系模式的集合则构成了数据库的模式。数据库的模式是对数据库逻辑上的总体描述。因此关系数据库的设计关键就是关系模式的设计。由于考虑问题的出发点和角度的不同,对一个给定的数据环境可以设计出多种不同的数据库模式,什么是好的数据库模式,怎样设计出一个好的数据库模式是我们下面将要讨论的问题。 由于关系模式反映了实体及实体内各属性之间的联系,因此关系模式的设计是建立在属性之间的依赖关系之上的,下面我们首先研究属性之间的依赖性。由于属性在数据世界中的对应项是数据项, 因此属性之间的依赖性又称为数据依赖性。 1. 数据依赖性 数据依赖主要分为函数依赖(FD)、多值依赖(MVD)和连接依赖(JD)三种形式。其中函数依赖和多值依赖是两种最重要的形式。 1) 函数依赖 函数依赖反映了单个属性或属性组间的一种单值依赖关系,这种依赖可用下面的定义来描述。 定义17.4 设有关系模式REL(A1,A2,…,An)简记为REL(U)和X、Y?U,如果对于REL上的任一关系r中的任意两个元组t1、t2有t1[X]=t2[X],则必有t1[Y]=t2[Y],就称X函数决定Y,或称Y函数依赖于X,记作X→Y。 定义17.4描述了这样一个事实,当t1、t2对应于X的那些属性的值相等时,则t1、t2中对应于Y的那些属性的值也一定相等。类比于数学中的函数关系,定义17.4可表述为,如果对REL中的属性或属性组X的每个值,REL中的Y只有一个值与之对应,则称Y函数依赖于X。函数依赖仅描述了Y对于X的依赖关系,并不涉及X对Y的依赖关系。 函数依赖关系是关系属性间常见的一种依赖关系。它是语义范畴的概念,只能根据语义来确定

文档评论(0)

aena45 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档