数据库习题解答
大学数据库-第1章习题解答

答案:A
〖1.34〗 数据库的特点之一是数据的共享,严格地讲,这里的数据共享是指_____。
A.同一个应用中的多个程序共享一个数据集合
B.多个用户、同一种语言共享数据
C.多个用户共享一个数据文件
D.多种应用、多种语言、多个用户相互覆盖地使用数据集合
答案:C
〖1.35〗 数据库(DB)、数据库系统(DBS)和数据库管理系统(DBMS)三者之间的关系
A.数据定义语言
B.数据管理语言
C.数据操纵语言
D.数据控制语言
答案:C
〖1.32〗 在数据库的三级模式结构中,描述数据库中全局逻辑结构和特征的是_____。
A.外模式
B.内模式
C.存储模式 D.模式
答案:D
〖1.33〗 数据库三级模式体系结构的划分,有利于保持数据库的_____。
A.数据独立性 B.数据安全性 C.结构规范化 D.操作可行性
D.程序的标准化
答案:A,B,C
〖1.22〗 在数据库管理系统中,______不是数据库存取的功能模块。
A.事务管理程序模块
B.数据更新程序模块
C.交互式程序查询模块
D.查询处理程序模块
答案:C
〖1.23〗 _____是按照一定的数据模型组织的,长期存储在计算机内,可为多个用户共享的
数据的聚集。
A.数据库系统 B.数据库
第 1 章习题解答
〖1.1〗 什么是数据?数据有什么特征?数据与信息有什么关系? 答:① 数据是用于载荷信息的物理符号。
② 数据的特征是:数据有“型”和“值”之分;数据受数据类型和取值范围的约束; 数据有定性表示和定量表示之分;数据应具有载体和多种表现形式。
③ 数据与信息的关系为:数据是信息的一种表现形式,正确的数据可表达信息,而虚 假、错误的数据所表达的是谬误,不是信息。 〖1.2〗 什么是数据处理?数据处理的目的是什么? 答:① 数据处理是指对数据的收集、组织、整理、加工、存储和传播等工作。围绕着数据 所做的工作均称为数据处理。② 数据处理目的为:收集信息并将信息用数据表示和保存, 为各种使用和数据处理提供数据;对数据进行变换、抽取和运算,从而得到更有用的数据, 以指导或控制人的行为或事物的变化趋势;使更多的人得到并理解信息,从而使信息的作用 充分发挥出来。 〖1.3〗 数据管理的功能和目标是什么? 答:数据管理的功能为:组织和保存数据功能;数据维护功能;数据查询和数据统计功能; 数据的安全和完整性控制功能。② 数据管理的目标是:收集完整的信息,将信息用数据表 示,按数据结构合理科学地组织并保存数据;为各种使用快速地提供需要的正确数据,并保 证数据的安全性和完整性。 〖1.4〗 什么是数据库?数据库中的数据有什么特点? 答:① 数据库是数据管理的新方法和技术,是按数据结构来存储和管理数据的计算机软件 系统。② 数据库中的数据具有数据整体性,即数据库中的数据要保持自身完整的数据结构; 数据库中的数据具有数据共享性,不同的用户可以按各自的用法使用数据库中的数据,多个 用户可以同时共享数据库中的数据资源。 〖1.5〗 什么是数据库管理系统?它的主要功能是什么? 答:① 数据库管理系统简称 DBMS,是专门用于管理数据库的计算机系统软件。② 数据 库管理系统能够为数据库提供数据的定义、建立、维护、查询和统计等操作功能,并完成对 数据完整性、安全性进行控制的功能。 〖1.6〗 数据冗余会产生什么问题? 答:数据冗余度大,会造成浪费存储空间的问题,使数据的存储、管理和查询都不容易实现。 同时,由于文件系统中相同的数据需要重复存储和各自的管理,数据冗余度大还会给数据的 修改和维护带来麻烦和困难,特别容易造成数据不一致的恶果。数据冗余度大时,由于数据 重复出现,还使得数据统计的结果不正确。 〖1.7〗 什么是数据的整体性?什么是数据的共享性?为什么要使数据有整体性和共享性? 答:① 数据的整体性是指在进行数据库设计时,要站在全局需要的角度进行抽象和组织 数据,要完整地、准确地描述数据自身和数据之间联系的情况,要建立适合整体需要的数 据模型。
数据库习题答案

一、new单选(共有题目12题)1.下列关于关系数据模型的术语中,哪一个术语所表达的概念与二维表中的“行”的概念最接近?A.属性B.关系C.域D.元组你的答案:D标准答案:D解答过程:二维表中的“行”即关系数据模型中的“元组”,二维表中的“列”即关系数据模型中的“属性”。
2.一间宿舍可以住多个学生,则实体宿舍和学生之间的联系是()A.一对一B.一对多C.多对多D.多对一你的答案:C标准答案:B解答过程:3.关于数据与信息,下面说法正确的是()A.信息与数据只有区别,没有联系B.数据是信息的物理表示和载体C.数据处理本质上就是信息处理D.数据与信息没有区别你的答案:标准答案:B解答过程:4.下列说法中正确的是()A.两个实体之间只能是一对一联系B.两个实体之间只能是一对多联系C.两个实体之间只能是多对多联系D.两个实体之间可以是以上三种之一联系你的答案:D标准答案:D解答过程:5.数据库DB、数据库系统DBS、数据库管理系统DBMS之间的关系是()A.DB包括DBS、DBMSB.DBMS包括DB、DBSC.DBS包括DBMS、DBD.没有任何关系你的答案:B标准答案:C解答过程:6.在下列关于关系表的陈述中,错误的是()A.表中任意两行的值不能相同B.表中任意两列的值不能相同C.行在表中的顺序无关紧要D.列在表中的顺序无关紧要你的答案:标准答案:B解答过程:7.SQL语言中,删除一个表的命令是()A.DELETEB.DROPC.CLEARD.REMOVE你的答案:B标准答案:B解答过程:SQL语言中,建立一个表的命令是CREATE,对表进行修改的命令是ALTER,删除一个表的命令是DROP,另外还有表中数据的插入,删除,查询命令分别为INSERT,DELETE 和SELECT。
8.在下面的两个关系中,学号和班级号分别为学生关系和班级关系的主键(或称主码),则外键是()学生(学号,姓名,班级号,成绩)班级(班级号,班级名,班级人数,平均成绩)A.学生关系的“学号”B.班级关系的“班级号”C.学生关系的“班级号”D.班级关系的“班级名”你的答案:C标准答案:C解答过程:外键的概念是:当关系中的某个属性(或属性组合)虽不是该关系的关键字或只是关键字的一部分,但却是另一个关系的关键字时,则称该属性(或属性组合)为这个关系的外部关键字或外键。
数据库习题集(附答案)

第一部分基本概念一,单项选择题1.在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。
在这几个阶段中,数据独立性最高的是阶段。
AA.数据库系统 B.文件系统C.人工管理 D.数据项管理2.数据库系统与文件系统的主要区别是。
BA.数据库系统复杂,而文件系统简单B.文件系统不能解决数据冗余和数据独立性问题,而数据库系统可以解决C.文件系统只能管理程序文件,而数据库系统能够管理各种类型的文件D.文件系统管理的数据量较少,而数据库系统可以管理庞大的数据量3.数据库的概念模型独立于。
AA.具体的机器和DBMS B.E-R图C.信息世界 D.现实世界4.数据库是在计算机系统中按照一定的数据模型组织、存储和应用的①,支持数据库各种操作的软件系统叫②,由计算机、操作系统、DBMS、数据库、应用程序及用户等组成的一个整体叫做③。
BBB① A.文件的集合 B.数据的集合C.命令的集合 D.程序的集合② A.命令系统 B.数据库管理系统C.数据库系统 D.操作系统③ A.文件系统 B.数据库系统C.软件系统 D.数据库管理系统5.数据库的基本特点是。
BA.(1)数据可以共享(或数据结构化) (2)数据独立性(3)数据冗余大,易移植 (4)统一管理和控制B.(1)数据可以共享(或数据结构化) (2)数据独立性(3)数据冗余小,易扩充 (4)统一管理和控制C.(1)数据可以共享(或数据结构化) (2)数据互换性(3)数据冗余小,易扩充 (4)统一管理和控制D.(1)数据非结构化 (2)数据独立性(3)数据冗余小,易扩充 (4)统一管理和控制6.数据库具有①、最小的②和较高的③。
BAC① A.程序结构化 B.数据结构化C.程序标准化 D.数据模块化② A.冗余度 B.存储量C.完整性 D.有效性③ A.程序与数据可靠性 B.程序与数据完整性C.程序与数据独立性 D.程序与数据一致性7.在数据库中,下列说法是不正确的。
数据库习题带答案

数据库习题带答案第⼀章绪论Ⅰ、学习要点1、准确掌握数据、数据库、数据库系统、数据库管理系统等基本术语、概念;2、数据独⽴性的概念、分类及实现途径;3、数据模型的概念、分类、要素及作⽤;4、数据库三级模式体系结构的含义及作⽤;5、关系数据模型的三要素内容。
Ⅱ、习题⼀、选择题:1、使⽤⼆维表格结构表达数据和数据间联系的数据模型是()A、层次模型B、⽹状模型C、关系模型D、实体—联系模型2、、、间的关系是()A、包括和B、包括和C、包括和D、与和⽆关3、在数据库中存储的是()A、数据B、数据模型C、数据及数据之间的联系D、信息4、数据库系统中,⽤()描述全部数据的整体逻辑结构。
A、外模式B、模式C、内模式D、数据模式5、数据库中,导致数据不⼀致的根本原因是()A、数据量太⼤B、数据安全性不⾼C、数据冗余D、数据完整性约束不强6、划分层次型、⽹状型和关系型数据库的原则是()A、记录的长度B、⽂件的⼤⼩C、联系的复杂程度D、数据及联系的表⽰⽅式7、数据库三级模式体系结构的划分,主要有利于保持数据库的()A、数据安全性B、数据独⽴性C、结构规范化D、操作可⾏性8、数据库系统中,⽤()描述⽤户局部数据的逻辑结构,它是⽤户和数据库系统间的接⼝。
A、外模式B、模式C、内模式D、数据模式9、数据库系统中,⽤()描述全部数据的物理存储视图。
A、外模式B、模式C、内模式D、数据模式10、数据库系统中⽤于定义和描述数据库逻辑结构的语⾔是()A、 B、 C、 D、11、数据库系统⽀持的数据共享指的是()A、同⼀应⽤的多个程序共享同⼀数据集合B、多个⽤户、同⼀语⾔程序共享同⼀数据集合C、多个⽤户共享同⼀数据⽂件D、多种语⾔、多个⽤户、多个应⽤相互覆盖地使⽤同⼀数据集合12、数据库系统中,当内模式发⽣变化时,采⽤()来保证数据的物理独⽴性。
A、修改模式定义B、修改模式\内模式映像C、修改应⽤程序D、修改外模式定义⼆、填空题1、指出下列缩写的含义:(1)(2)(3)(4)(5)(6)(7)2、数据管理技术经历了(1)、(2)、(3)三个阶段。
数据库理论习题及答案

单项选择1. 现有学生关系Student ,属性包括学号(Sno),姓名(Snam© ,所在系(Sdept), 系主任姓名(Mnam©,课程名(Cn am©和成绩(Grade)。
这些属性之间存在如下联系:一个学号只对应一个学生;一个学生只对应一个系;一个系只对应一个系主任;一个学生的一门课只对应一个成绩;学生名可以重复;系名不重复;课程名不重复。
则以下不正确的函数依赖是(C)。
A. Sno f Sdept「B. Sno f Mn amepC. Sn ame f SdeptpD. Sno Cn ame f Grade2. 下面关于函数依赖的描述,错误的是(D)。
厂A.在函数依赖A fB中,A称为决定因素「B.在关系R中,属性B依赖于属性A,则说明当属性A的值确定之后,属性B的值也就随之确定厂C.函数依赖具有传递性厂D.在关系R中,如果属性A依赖于属性B,这种依赖正式记作:A fB3. 现给定一个关系R的实例如下表,则可能是函数依赖的是(B)。
A. F1 f F2B. F1 F2 f F5C. F3 F4 f F5D. F2 F3 — F44. 关系R包含属性{A1 , A2, A3, A4, A5},其中{A1 , A2}为键码(key),则下面的说法正确的是(C )。
A. {A1}或者{A2}有可能单独成为R的键码广B. {A1,A2, A3}必然也是R的键码广C. R中绝不可能出现两个在A1、A2上取值完全相同的元组厂D. R的所有元组中,A1或者A2的值都是不能重复的5. 下面关于键码的说法,错误的是()。
' A. 一个关系的键码是惟一的r B. 一个关系的键码指定值之后,对应的元组也就确定了「C.关系R的键码的任何真子集都不可能是关系R的键码广D.在保存学生学籍信息处的关系,学生姓名对应的属性不适合单独作为键码6. 在给出的如下表所示关系实例中,有可能作为键码的是(C )。
数据库课后习题答案

第一章绪论1、试述数据、数据库、数据库管理系统、数据库系统的概念。
答:描述事物的符号记录称为数据;数据库是长期储存在计算机内的、有组织的、可共享的数据集合;数据库管理系统是位于用户与操作系统之间的一层数据管理软件; 数据库系统是指在计算机系统中引入数据库后的系统,一般由数据库、数据库管理系统(及其开发工具)、应用系统、数据库管理员和用户构成。
2.使用数据库系统有什么好处?答:数据库系统使信息系统从以加工数据的程序为中心转向围绕共享的数据库为中心的阶段,这样既便于数据的集中管理,又有利于应用程序的研制和维护,提高了数据的利用率和相容性,提高了决策的可靠性。
3.试述文件系统与数据库系统的区别和联系。
答:1)数据结构化是数据库与文件系统的根本区别。
在文件系统中,相互独立的文件的记录内部是有结构的,管其记录内部已有了某些结构,但记录之间没有联系。
数据库系统实现整体数据的结构化,是数据库的主要特征之一。
2)在文件系统中,数据的最小存取单位是记录,粒度不能细到数据项。
而在数据库系统中,存取数据的方式也很灵活,可以存取数据库中的某一个数据项、一组数据项一个记录或或一组记录。
3)文件系统中的文件是为某一特定应用服务的,文件的逻辑结构对该应用程序来说是优化的,因此要想对现有的数据再增加一些新的应用会很困难,系统不容易扩充。
而在数据库系统中数据不再针对某一应用,而是面向全组织,具有整体的结构化。
5.试述数据库系统的特点。
答:数据结构化;数据的共享性高、冗余度低、易扩充;数据独立性高;数据由DBMS统一管理和控制。
6.数据库管理系统的主要功能有哪些?答:数据定义功能、数据操纵功能、数据库的运行管理、数据库的建立和维护功能。
7.试述数据模型的概念(13页)、数据模型的作用、数据模型的三个要素。
答:数据模型(Data Model)也是一种模型,它是现实世界数据特征的抽象。
作用:在数据库中用数据模型来抽象、表示和处理现实世界中的数据和信息。
数据库 练习题(答案)

第四章练习题一、选择题1、设有两个关系R(A,B)和S(B,C),与下列SELECT语句SELECT A,B FROM RWHERE B NOT IN(SELECT B FROM S WHERE C='C56');等价的关系代数表达式是 [ C]A.πA,B(σC≠'C56'(R⋈S))B.πA,B(R ⋈ S)C≠'C56' C.R-πA,B(σC= 'C56'(R⋈S))D.R-πA,B(σC≠'C56'(R⋈S))2、嵌入式SQL的预处理方式,是指[ B]A.识别出SQL语句,加上前缀标识和结束标志B.把嵌入的SQL语句处理成函数调用形式C.对源程序进行格式化处理D.把嵌入的SQL语句编译成目标程序3、SQL中,“DELETE FROM 表名”表示 [ A]A.从基本表中删除所有元组B.从基本表中删除所有属性C.从数据库中撤消这个基本表D.从基本表中删除重复元组4、SQL中,聚合函数COUNT(列名)用于[ C]A.计算元组个数B.计算属性的个数C.对一列中的非空值计算个数D.对一列中的非空值和空值计算个数5、在传统SQL技术中,使用“ORDER BY”子句的SELECT语句查询的结果,实际上为 [B]A.数组 B.列表 C.包 D.集合6、在数据库中,能提高查询速度的是(C )A. 数据依赖B. 视图C. 索引D. 数据压缩7、语句 delete from sc 表明( A )A. 删除sc中的全部记录B. 删除基本表scC. 删除基本表sc中的列数据D. 删除基本表sc中的部分行8、在DB应用中,一般一条SQL 语句可产生或处理一组记录,而DB主语言语句一般一次只能处理一条记录,其协调可通过( B )实现。
A. 指针B. 游标C. 数组D. 栈9、在下列基本表的定义中,数值5表示( C )CREATE TABLE student (Sno char(5) not null unique,Sname char(2));A. 表中有5条记录B. 表中有5列C. 表中字符串Sno 的长度D. 表格的大小10、在视图上不能完成的操作是( C )A. 更新视图B. 查询C. 在视图上定义新的基本表D. 在视图上定义新视图11、下列聚合函数中不忽略空值 (null) 的是(C)A、SUM (列名)B、MAX (列名)C、COUNT ( * )D、AVG (列名)12、SQL的查询语句的where子句中,对空值的操作,不正确的是( C )A、where AGE IS NULLB、where AGE IS NOT NULLC、where AGE = NULLD、where NOT (AGE IS NULL)13、Transact-SQL对标准SQL的扩展主要表现为( A )。
数据库习题答案

整理课件
练习二(E-R图)
一、研究所有若干研究室,每一个研究室多位科研人员在指 定的办公地点。每一位科研人员只属于一个研究所,有编 号、姓名、性别和年龄。研究所承担了多个科研项目,包 括责任人、项目号、项目名和开工时间(每位科研人员可 以参加多个科研项目),每个科研项目有多位科研人员参 加,科研人员参加科研项目均有相应的工作量
6
二、单项选择题
1、( A )不是SQL语言的标准。P156 A.SQL-84 B.SQL-86 C.SQL-89 D.SQL-92
整理课件
2、 ( D )数据模型没有被商用DBMS实现。P26 A.关系模型 B.层次模型 C.网状模型 D.E-R模型
3、( C )不是数据模型应满足的要求。P12
WHERE C.Cid = SC.Cid AND S.Sid = ‘S3’
20
4、检索至少选修LIU老师所授课程中一门课的女学生姓名。 S n a m e ( T e a c h e r " L I U " ( C )S C S e x " 女 " ( s ) )
SELECT Sname
1、检索LIU老师所授课程的课程号和课程名。 ( ( C ) ) C i d ,C n a m e T e a c h e r " L I U "
SELECT Cid, Cname FROM C WHERE Teacher = ‘LIU’
19
2、检索年龄大于 23岁的男学生的学号和姓名。 ( ( S ) ) S i d , S n a m eA g e 2 3 S e x " 男 "
整理课件
SELECT FROM WHERE
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
习题一1. 试回答下列问题(1)什么是数据库?(2)什么是数据库管理系统?(3)什么是数据库系统?答:(1)数据库是被长期存放在计算机内,有组织的,统一管理的相关数据的集合。
(2) 数据库管理系统(Data Base Management System, 简称DBMS),是位于用户与操作系统之间的一层数据管理软件,它属于系统软件,它为用户或应用程序提供访问DB的方法,包括DB的建立、查询、更新及各种数据控制。
(3) 数据库系统(DBS)通常是指带有数据库的计算机应用系统。
DBS是一个实际可运行的,按照数据库方法存储、维护和向应用系统提供数据支持的系统,它是数据库、硬件、软件和数据库管理员(DBA)的集合体。
2. 计算机数据管理经历了哪几个阶段?答:数据管理技术的发展经历了三个阶段:人工管理阶段、文件系统阶段、数据库系统阶段。
3. 试述文件系统的缺点。
答:(1)数据共享性差,冗余度大。
(2)数据不一致性。
(3)数据联系弱。
4. 试述数据库系统的特点。
答:(1)采用复杂的数据模型表示数据结构。
(2)有较高的数据独立性。
(3)数据的共享性高,冗余度低,易扩充。
(4)数据由DBMS统一控制和管理。
5. 试述概念模型的作用。
答:概念模型是独立于计算机系统的数据模型,它完全不涉及信息在计算机系统中的表示,只是用来描述某个特定组织所关系的信息结构。
概念模型用于建立信息世界的数据模型,强调其语义表达能力,概念应该简单、清晰、易于用户理解,它是现实世界的第一层抽象,是用户和数据库设计人员之间进行交流的工具。
这一模型中最著名的是“实体联系模型”。
6. 解释下列概念:内模式、模式、外模式、DDL、DML答:内模式也称存储模式(Storage Schema)。
它是数据物理结构和存储方式的描述,是数据在数据库内部的表示方式。
一个数据库只有一个内模式。
模式也称逻辑模式,是数据库中全体数据的逻辑结构和特征的描述,是所有用户的公共数据视图。
它是数据库系统模式结构的中间层。
外模式也称子模式(Subschema)或用户模式,它是用户与数据库系统的接口,是用户用到的那部分数据的逻辑结构和特征的描述,是数据库用户的数据视图。
DDL是数据定义语言(Data Definition Language-DDL),用户通过它可以方便地对数据库中的数据对象进行定义。
DML是数据操纵语言(Data Manipulation Language-DML),实现对数据库中数据的操作。
7. 试述数据库系统三级模式结构,这种结构的优点是什么?答:数据库系统的体系结构分成三级:内部级(internal),概念级(conceptual)和外部级(external)。
这个三级结构也称数据库系统的“三级模式结构”。
内部级也称“内模式”,概念级也称“模式”,外部级也称“外模式”,故数据库系统是由外模式、模式和内模式三级构成,如下图所示:8. 试述数据库的物理独立性和逻辑独立性。
答:数据的独立性包括数据的物理独立性和数据的逻辑独立性。
数据的物理独立性是指当数据在计算机存储设备上的物理存储改变时,应用程序可以不用改动,而由DBMS来处理这种改变。
数据逻辑独立性是指当数据的整体逻辑结构改变时,不影响用户的逻辑结构以及应用程序。
9. DBS由哪几部分组成?DBA的职责是什么?答:DBS一般由数据库(即实际存储在计算机中的数据)、数据库管理系统、相应的硬件、软件和各类人员构成。
数据库系统是一个有使用人员及维护人员、加工设备和数据资源的完整的计算机应用系统。
DBA是数据资源管理机构的一组人员。
总的来说,负责全面地管理和控制数据库系统。
具体职责包括:(a) 决定数据库的信息内容和结构(b) 决定数据库的存储结构和存取策略(c) 定义数据的安全性要求和完整性的约束条件(d) 监督和控制数据库的使用和运行(e) 数据库的改进和重组10. 数据库管理系统的主要功能有哪些?答:DBMS的主要功能包括以下几个方面:①数据定义功能②数据操纵功能③数据库的运行管理④数据库的建立和维护功能11. 试述DBMS在用户访问数据库过程中所起的作用。
答:应用程序通过DBMS读取数据库中记录,DBMS为程序开辟一个数据库的系统缓冲区,用于数据的传输和格式的转换。
12.试写出用户访问数据库的过程。
答:(1)用户在应用程序中安排一条读记录的DML语句。
该语句给出涉及的外模式中记录类型名及键值。
当计算机执行该DML语句时,立即启动DBMS,并把读记录的命令传给DBMS。
(2)DBMS接到命令后,加以分析,并调出程序A对应的外模式,检查该操作的合法权限,决定是否执行该命令。
(3)在决定执行A的命令后,DBMS调出相应的模式描述,并从外模式映象到模式,决定应读入哪些模式记录。
(4)DBMS调出相应的内模式描述,并将模式映象成为模式的内部记录模式,确定应读入哪些物理记录。
(5)DBMS向操作系统(OS)发出从指定地址读取物理记录的命令。
(6)OS执行该命令,按指定地址从数据库把记录读入OS的系统缓冲区,进而读入数据库的系统缓冲区,并在操作结束后向DBMS作出回答。
(7)DBMS收到OS的回答后,将读入缓冲区中的数据转换成模式记录,外部记录。
(8)DBMS把导出的外部记录从系统缓冲区送到应用程序A的工作区中。
(9)DBMS向运行日志数据库中写入读一条记录的信息。
(10)DBMS将读记录成功与否信息返回给程序A。
(11)程序A决定是否使用工作区中的数据。
习题二1. 试述关系模型的3个组成部分。
答:关系模型是由关系数据结构、关系操作集合和关系完整性约束三部分组成。
这是关系模型的三要素。
2.定义并理解下列术语。
(1)域,笛卡尔积,关系,元组,属性(2)主键,候选键,外键答:(1)域:一组具有相同数据类型的值的集合。
给定一组域D1,D2,…,Dn,其笛卡尔积为:D1×D2×…×Dn={(d1,d2,…,dn)|di ∈Di, i= 1, 2, …, n },其中每一元素(d1,d2,…,dn)叫做一个元组(Tuple)。
D1×D2×…×Dn 的子集叫做域D1,D2,…,Dn上的关系。
关系是笛卡尔积的有限子集,所以关系也是一个二维表,表的每一行表示一个元组,表的每一列对应一个域。
对每列起一个名字,称为属性(Attribute)。
(2)如果一个属性集能唯一标识元组,又不含有多余属性,那么这个属性集称为候选键。
主键(primary key):用户选作元组标识的一个候选键称为主键。
注意:若一个关系有多个候选键,只能指定其中一个为主键。
如果关系中的属性或属性组不是本关系的主键,而是引用另一个关系的主键,则称这一属性或属性组为外键。
3. 试回答下列问题:(1)可以表示任何关系代数操作的五种基本代数操作是什么?(2)连接、等值连接、自然连接、外连接、半连接的区别是什么?(3)元组关系演算表达式和域关系演算表达式的区别是什么?(4)域关系演算表达式的安全性定义是什么?答:(1)关系代数操作的五种基本代数操作是并、差、笛卡尔积、投影、选择。
(2)连接也称为θ连接。
它是从两个关系的笛卡尔积中选取属性间满足一定条件的元组。
θ为“=”的连接运算称为等值连接。
它是从关系R与S的广义笛卡尔积中选取A,B属性值相等的那些元组。
自然连接(Natural join)是一种特殊的等值连接,它要求两个关系中进行比较的分量必须是相同的属性组,并且在结果中把重复的属性列去掉。
如果在R和S 做自然连接时,保留被舍弃的元组,其空缺的另一关系的属性的值用空值(mull)填充,那么这种操作称为“外连接”操作。
关系R和S的半连接操作记为R S,定义为R和S的自然连接在关系R的属性集上的投影,(3)在元组关系演算系统中,我们称{t| P (t) }型表达式为元组演算表达式,其中P(t)是元组关系演算公式,t是元组变量。
一个元组演算表达式表示一个关系。
域关系演算类似于元组关系演算,不同的是用域变量代替元组变量。
域关系演算的变量在域中取值,故称为域变量,每个自由变量对应一个列或一个属性。
(4)如果域关系演算表达式满足以下三个条件则是安全的:(1)每一个关系代数表达式有一个等价的、安全的元组演算表达式。
(2)每一个安全的元组演算表达式有一个等价的安全域演算表达式。
(3)每一个安全的域演算表达式有一个等价的关系代数表达式。
4.答:R∪SR∩S:R-S:R×S:5 . 设有关系R 和S ,如图2-10所示。
计算:R ×S , R S ,σA =C (R ×S )。
答:R ×S:R S:σA =C6. 如果R是二目关系,那么下列元组表达式的结果是什么?{t∣(∃ u)(R(t)∧R(u)∧(t [1]≠u [1]∨t [2]≠u [2]))}答:当R的元组数≥2时,R中每个元组都存在与之不相同的元组,因此表达式的结果为关系R;当R的元组数为0或1时,表达式的结果为空关系R。
7. 设有两个关系R(A,B,C)和S(D,E,F)。
试表下列关系代数表达式转换成等价的元组表达式:(1)πA(R)(2)σB=’19’(R)(3)R×S (4)πA,F(σC=D(R×S))答:(1)πA(R)转换成{t∣(∃ u)(R(u)∧t [1]=u [1])}(2)σB=’19’(R)转换成{t∣R(t)∧t [2]=‘19’)}(3)R×S转换成{t∣(∃ u) (∃ v)(R(u)∧S(v)∧t [1]=u [1] ∧t [2]=u [2] ∧t [3]=u [3] ∧t [4]=v [1] ∧t [5]=v [2] ∧t [6]=v [3])}(4)πA,F(σC=D(R×S))转换成{t∣(∃ u) (∃ v)(R(u)∧S(v)∧t [1]=u [1] ∧t [2]=v [3] ∧u [3]=v [1])}8. 已知学生一课程数据库的三个关系。
S(学生关系),C(课程关系),SC(学生选课关系)。
S(S#,SN,SD,SA)SC(S#,C#,GS)C(C#,CN,PC#)试用关系代数表达式表示下列查询要求:(1)取出所有学生的全部细节答:πS#,SN,SD,SA(S)(2)取出选修课程号为‘C2’的学生姓名及所属的系。
答:πSN,SD(s πS# (σc#=‘C2’(SC)))(3)取出同时选修课程号为‘C1’和‘C2’两门课程的学生名字。
答:πSN (πS#,c#(SC)÷πc#(σc#=’C1’∨c#=’c2’(C)) S)(4)取出选修“BASIC”语言这门课程的学生姓名。
答:πSN(s πS# (σcN=‘BASIC’(C) SC))(5)取出年龄大于23岁的计算机系的学生姓名。