1、数据库系统概论复习资料:第一章:一、选择题:1在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。在这几个阶段中,数据独立性最高的是 A 阶段。A数据库系统 B文件系统 C人工管理 D数据项管理 2数据库的概念模型独立于 A 。A具体的机器和 DBMS BE-R 图 C信息世界 D现实世界 3数据库的基本特点是 B 。A(1)数据可以共享(或数据结构化) (2)数据独立性 (3)数据冗余大,易移植 (4)统一管理和控制B(1)数据可以共享(或数据结构化) (2)数据独立性 (3)数据冗余小,易扩充 (4)统一管理和控制C(1)数据可以共享(或数据结构化) (2)数据互
2、换性 (3)数据冗余小,易扩充 (4)统一管理和控制D(1)数据非结构化 (2)数据独立性 (3)数据冗余小,易扩充 (4)统一管理和控制 4. B 是存储在计算机内有结构的数据的集合。A数据库系统 B数据库 C数据库管理系统 D数据结构 5数据库中存储的是 C 。A数据 B数据模型 C数据以及数据之间的联系 D信息 6. 数据库中,数据的物理独立性是指 C 。A数据库与数据库管理系统的相互独立 B用户程序与 DBMS 的相互独立C用户的应用程序与存储在磁盘上数据库中的数据是相互独立的 D应用程序与数据库中数据的逻辑结构相互独立 7. 数据库的特点之一是数据的共享,严格地讲,这里的数据共享是指
3、 D 。A同一个应用中的多个程序共享一个数据集合 B多个用户、同一种语言共享数据C多个用户共享一个数据文件 D多种应用、多种语言、多个用户相互覆盖地使用数据集合 8.数据库系统的核心是 B 。A数据库 B数据库管理系统 C数据模型 D软件工具 9. 下述关于数据库系统的正确叙述是 A 。A数据库系统减少了数据冗余 B数据库系统避免了一切冗余C数据库系统中数据的一致性是指数据类型一致 D数据库系统比文件系统能管理更多的数据 10. 数将数据库的结构划分成多个层次,是为了提高数据库的 和 。A数据独立性 B逻辑独立性 C管理规范性 D数据的共享A数据独立性 B物理独立性 C逻辑独立性 D管理规范性
4、 【答案:】B B11. 数据库(DB)、数据库系统(DBS)和数据库管理系统(DBMS)三者之间的关系是 A 。ADBS 包括 DB 和 DBMS BDDMS 包括 DB 和 DBS CDB 包括 DBS 和 DBMS DDBS 就是 DB,也就是 DBMS12. 在数据库中,产生数据不一致的根本原因是 D 。A数据存储量太大 B没有严格保护数据 C未对数据进行完整性控制 D数据冗余 13. 数据库管理系统(DBMS)是 D 。A数学软件 B应用软件 C计算机辅助设计 D系统软件 14. 数据库管理系统(DBMS)的主要功能是 B 。A修改数据库 B定义数据库 C应用数据库 D保护数据库 1
5、5. 数据库系统的特点是 A 、数据独立、减少数据冗余、避免数据不一致和加强了数据保护。A数据共享 B数据存储 C数据应用 D数据保密 16 数据库系统的最大特点是 A 。A数据的三级抽象和二级独立性 B数据共享性 C数据的结构化 D数据独立性 17. 数据库管理系统能实现对数据库中数据的查询、插入、修改和删除等操作,这种功能称为 C 。A数据定义功能 B数据管理功能 C数据操纵功能 D数据控制功能 18. 数据库管理系统是 B 。A操作系统的一部分 B在操作系统支持下的系统软件 C一种编译程序 D一种操作系统 19.数据库的三级模式结构中,描述数据库中全体数据的全局逻辑结构和特征的是(D)A
6、外模式 B内模式 C存储模式 D模式 20 数据库系统的数据独立性是指 B 。 A不会因为数据的变化而影响应用程序B不会因为系统数据存储结构与数据逻辑结构的变化而影响应用程序C不会因为存储策略的变化而影响存储结构 D不会因为某些存储结构的变化而影响其他的存储结构21.信息世界中的术语,与之对应的数据库术语为 D 。A文件 B数据库 C字段 D记录 22 次型、网状型和关系型数据库划分原则是 D 。A记录长度 B文件的大小 C联系的复杂程度 D数据之间的联系 23.传统的数据模型分类,数据库系统可以分为三种类型 C 。A大型、中型和小型 B西文、中文和兼容 C层次、网状和关系 D数据、图形和多媒
7、体 24. 层次模型不能直接表示 C 。A 1 :1 关系 B1 :m 关系 C m :n 关系 D1 :1 和 1 :m 关系 25. 数据库技术的奠基人之一 E.FCodd 从 1970 年起发表过多篇论文,主要论述的是 C 。A层次数据模型 B网状数据模型 C关系数据模型 D面向对象数据模型 二、填空题1. 数据管理技术经历了 人工管理 、 文件系统 和 数据库系统 三个阶段。 【答案:】人工管理 文件系统 数据库系统2. 数据库是长期存储在计算机内、有 组织的、可共享的数据集合。 【答案:】组织 共享3DBMS 是指 它是位于 用户 和 之间的一层管理软件。 【答案:】数据库管理系统
8、用户 操作系统4. 数据库管理系统的主要功能有数据定义功能 、数据操纵功能 、数据库的运行管理和数据库的建立以及维护等 4 个方面。【答案:】数据定义功能 数据操纵功能5. 数据独立性又可分为逻辑数据独立性 和 物理数据独立性。 【答案:】逻辑数据独立性 物理数据独立性6. 当数据的物理存储改变了,应用程序不变,而由 DBMS 处理这种改变,这是指数据的 物理独立性 。 【答案:】物理独立性7. 数据模型是由数据结构 、数据操作 和完整性约束 三部分组成的。 【答案:】数据结构 数据操作 完整性约束8. 数据结构 是对数据系统的静态特性的描述,数据操作 是对数据库系统的动态特性的描述。 【答案
9、:】数据结构 数据操作9. 数据库体系结构按照 模式 、 外模式 和 内模式 三级结构进行组织。 【答案:】模式 外模式 内模式10. 实体之间的联系可抽象为三类,它们是 11 、 1m 和 mn 。 【答案:】11 1m mn11数据冗余可能导致的问题有 和 。 【答案:】浪费存储空间及修改麻烦 潜在的数据不一致性三:简答题:1. 什么是数据库?答:数据库是长期存储在计算机内、有组织的、可共享的数据集合。数据库是按某种数据模型进行组织的、存放在外存储器上,且可被多个用户同时使用。因此,数据库具有较小的冗余度,较高的数据独立性和易扩展性。2. 什么是数据库的数据独立性?答:数据独立性表示应用程
10、序与数据库中存储的数据不存在依赖关系,包括逻辑数据独立性和物理数据独立性。逻辑数据独立性是指局部逻辑数据结构(外视图即用户的逻辑文件)与全局逻辑数据结构(概念视图)之间的独立性。当数据库的全局逻辑数据结构(概念视图)发生变化(数据定义的修改、数据之间联系的变更或增加新的数据类型等)时,它不影响某些局部的逻辑结构的性质,应用程序不必修改。物理数据独立性是指数据的存储结构与存取方法(内视图)改变时,对数据库的全局逻辑结构(概念视图)和应用程序不必作修改的一种特性,也就是说,数据库数据的存储结构与存取方法独立。3. 什么是数据库管理系统?答:数据库管理系统(DBMS)是操纵和管理数据库的一组软件,它
11、是数据库系统(DBS)的重要组成部分。不同的数据库系统都配有各自的 DBMS,而不同的 DBMS 各支持一种数据库模型,虽然它们的功能强弱不同,但大多数DBMS 的构成相同,功能相似。一般说来,DBMS 具有定义、建立、维护和使用数据库的功能,它通常由三部分构成:数据描述语言及其翻译程序、数据操纵语言及其处理程序和数据库管理的例行程序。4. 什么是数据字典?数据字典包含哪些基本内容?答:数据字典是数据库系统中各种描述信息和控制信息的集合,它是数据库设计与管理的有力工具,是进行详细数据收集和数据分析所获得的主要成果。数据字典的基本内容有:数据项、数据结构、数据流、数据存储和处理过程 5 个部分。
12、第一章补充作业部分:一、假设教学管理规定:一个学生可选修多门课,一门课有若干学生选修;一个教师可讲授多门课,一门课只有一个教师讲授;一个学生选修一门课,仅有一个成绩。学生的属性有学号、学生姓名;教师的属性有教师编号,教师姓名;课程的属性有课程号、课程名。要求:根据上述语义画出 ER 图,要求在图中画出实体的属性并注明联系的类型;解答:二、某企业集团有若干工厂,每个工厂生产多种产品,且每一种产品可以在多个工厂生产,每个工厂按照固定的计划数量生产产品;每个工厂聘用多名职工,且每名职工只能在一个工厂工作,工厂聘用职工有聘期和工资。工厂的属性有工厂编号、厂名、地址,产品的属性有产品编号、产品名、规格,
13、职工的属性有职工号、姓名。(1)根据上述语义画出 E-R 图; (2)将该 E-R 模型转换为关系模型; (要求:1:1 和 1:n 的联系进行合并)(3)指出转换结果中每个关系模式的主码和外码。答案:(1)本题的 E-R 图如下图所示。成绩教师编号 教师姓名学生 选修m 课程教师讲授nn1学号姓名课程号 课程名(2)转化后的关系模式如下:工厂(工厂编号,厂名,地址)产品(产品编号,产品名,规格)职工(职工号,姓名,工厂编号,聘期,工资)生产(工厂编号,产品编号,计划数量)(3)每个关系模式的主码、外码如下:工厂:主码是工厂编号,无外码;产品:主码是产品编号,无外码;职工:主码职工号,外码是工
14、厂编号;生产:主码是(工厂编号,产品编号) ,外码是工厂编号、产品编号。第 2 章关系数据库一、选择题1、关系数据库管理系统应能实现的专门关系运算包括 B 。A排序、索引、统计 B选择、投影、连接 C关联、更新、排序 D显示、打印、制表 2、关系模型中,一个关键字是 C 。A可由多个任意属性组成 B至多由一个属性组成 C可由一个或多个其值能惟一标识该关系模式中任何元组的属性组成 D以上都不是 3、自然连接是构成新关系的有效方法。一般情况下,当对关系 R 和 S 使用自然连接时,要求 R 和 S 含有一个或多个共有的 D 。A元组 B行 C记录 D属性 规格n1m n工厂生产 产品聘用职工职工号
15、 姓名工资计划数量产品编号 产品名工产编号 厂名聘期地址4、关系运算中花费时间可能最长的运算是 C 。A投影 B选择 C笛卡尔积 D除 5关系模式的任何属性 A 。A不可再分 B可再分 C命名在该关系模式中可以不惟一 D以上都不是 6在关系代数运算中,五种基本运算为 C 。A并、差、选择、投影、自然连接 B并、差、交、选择、投影 C并、差、选择、投影、乘积 D并、差、交、选择、乘积 7、如图所示,两个关系 R1 和 R2,它们进行 D 运算后得到 R3。R2R1A B CACD121XYyR3A B C D EACC112XYyMMNIIJA交 B并 C笛卡尔积 D连接 二、填空题1、一个关系
16、模式的定义格式为 。 【答案:】关系名(属性名 1,属性名 2,属性名 n)2、 一个关系模式的定义主要包括 关系名 、属性名 、 属性类型 、属性长度 和关键字 。 【答案:】关系名 属性名 属性类型 属性长度 关键字3、 关系代数运算中,传统的集合运算有 、 、 和 。 【答案:】笛卡尔积 并 交 差4、关系代数运算中,基本的运算是 、 、 、 和 。 【答案:】并 差 笛卡尔积 投影 选择5、关系代数运算中,专门的关系运算有 选择 、 投影 和 连接 。 【答案:】选择 投影 连接6、关系数据库中基于数学上两类运算是关系代数 和关系演算 。D E M125MNMIJK【答案:】关系代数
17、关系演算7、 已知系(系编号,系名称,系主任,电话,地点)和学生(学号,姓名,性别,入学日期,专业,系编号)两个关系,系关系的主关键字是 ,系关系的外关键字 ,学生关系的主关键字是 ,外关键字 【答案:】系编号 无 学号 系编号第 3 章关系数据库标准语言 SQL一、选择题1、SQL 语言是 B 的语言,易学习。A过程化 B非过程化 C格式化 D导航式 2、SQL 语言是 C 语言。A层次数据库 B网络数据库 C关系数据库 D非数据库 3、SQL 语言具有 B 的功能。A关系规范化、数据操纵、数据控制 B数据定义、数据操纵、数据控制C数据定义、关系规范化、数据控制 D数据定义、关系规范化、数据
18、操纵 4、SQL 语言具有两种使用方式,分别称为交互式 SQL 和 C 。A提示式 SQL B多用户 SQL C嵌入式 SQL D解释式 SQL 5、假定学生关系是 S(S#,SNAME,SEX,AGE),课程关系是 C(C#,CNAME,TEACHER),学生选课关系是SC(S#,C#,GRADE)。 要查找选修“COMPUTER”课程的“女”学生姓名,将涉及到关系 D 。AS BSC,C CS,SC DS,C,SC 6、如下面的数据库的表中,若职工表的主关键字是职工号,部门表的主关键字是部门号,SQL 操作 B 不能执行。A从职工表中删除行(025 , 王芳 , 03,720) B将行(0
19、05, , 乔兴 , 04,750)插入到职工表中C将职工号为, 001的工资改为 700 D将职工号为, 038的部门号改为03 7、若用如下的 SQL 语句创建一个 student 表:CREATE TABLE student(NO C(4) NOT NULL,NAME C(8) NOT NULL,SEX C(2),AGE N(2)可以插入到 student 表中的是 B 。A(1031 , 曾华 ,男,23) B(1031 , 曾华 ,NULL,NULL)C(NULL, 曾华 , 男 , 23) D(1031 ,NULL, 男 ,23) 第 8 到第 11 题基于这样的三个表即学生表 S
20、、课程表 C 和学生选课表 SC,它们的结构如下:S(S#,SN,SEX,AGE,DEPT)C(C#,CN)SC(S#,C#,GRADE)其中:S#为学号,SN 为姓名,SEX 为性别,AGE 为年龄,DEPT 为系别,C#为课程号,CN 为课程名,GRADE 为成绩。8、检索所有比“王华”年龄大的学生姓名、年龄和性别。正确的 SELECT 语句是 A ASELECT SN,AGE,SEX FROM SWHERE AGE(SELECT AGE FROM SWHERE SN=“王华”)BSELECT SN,AGE,SEX FROM SWHERE SN“王华”CSELECT SN,AGE,SEX
21、FROM SWHERE AGE(SELECT AGEWHERE SN=“王华”)DSELECT SN,AGE,SEX FROM SWHERE AGE王华AGE 9、检索选修课程“C2”的学生中成绩最高的学生的学号,正确的 SELECT 语句是 D 。ASELECT S# FORM SC WHERE C#=“C2” AND GRAD(SELECT GRADE FORM SCWHERE C#=“C2”)BSELECT S# FORM SCWHERE C#=“C2” AND GRADE IN(SELECT GRADE FORM SCWHERE C#=“C2”)CSELECT S# FORM SCWH
22、ERE C#=“C2” AND GRADE NOT IN(SELECT GRADE FORM SCWHERE C#=“C2”)DSELECT S# FORM SCWHERE C#=“C2” AND GRADEALL(SELECT GRADE FORM SCWHERE C#=“C2”)10、检索学生姓名及其所选修课程的课程号和成绩。正确的 SELECT 语句是 C 。ASELECT SSN,SCC#,SCGRADEFROM SWHERE SS#=SCS#BSELECT SSN,SCC#,SCGRADEFROM SCWHERE SS#SCGRADECSELECT SSN,SCC#,SCGRADEF
23、ROM S,SCWHERE SS#=SCS#DSELECT SSN,SCC#,SCGRADEFROM SSC11、检索选修四门以上课程的学生总成绩(不统计不及格的课程),并要求按总成绩的降序排列出来。正确的 SELECT 语句是 D 。ASELECT S#,SUM(GRADE)FROM SCWHERE GRADE=60GROUP BY S#ORDER BY 2 DESCHAVING COUNT(*)4 WHERE C#=“C2” AND GRADE(SELECT GRADE FORM SCWHERE C#=“C2”)BSELECT S# FORM SCWHERE C#=“C2” AND GRA
24、DE IN(SELECT GRADE FORM SCWHERE C#=“C2”)CSELECT S# FORM SCWHERE C#=“C2” AND GRADE NOT IN(SELECT GRADE FORM SCWHERE C#=“C2”)DSELECT S# FORM SCWHERE C#=“C2” AND GRADEALL(SELECT GRADE FORM SCWHERE C#=“C2”)二、填空题1、SQL 是 结构化查询语言 。 【答案:】结构化查询语言2、视图是一个虚表,它是从 中导出的表。在数据库中,只存放视图的 ,不存放视图的 。 【答案:】一个或几个基本表 定义 视图对
25、应的数据3、设有如下关系表 R:R(No,NAME,SEX,AGE,CLASS)主关键字是 NO其中 NO 为学号,NAME 为姓名,SEX 为性别,AGE 为年龄,CLASS 为班号。写出实现下列功能的 SQL 语句。插入一个记录(25, “李明” , “男” ,21, “95031”); 。插入“95031”班学号为 30、姓名为“郑和”的学生记录; 。将学号为 10 的学生姓名改为“王华” ; 。将所有“95101”班号改为“95091” ; 。删除学号为 20 的学生记录; 。删除姓“王”的学生记录; 。【答案:】INSERT INTO R VALUES(25, “李明” , “男”
26、,21, “95031”)INSERT INTO R(NO,NAME,CLASS) VALUES(30, “郑和” , “95031”)UPDATE R SET NAME=“王华”WHERE NO10UPDATE R SET CLASS“95091”WHERE CLASS“95101”DELETE FROM R WHERE NO=20DELETE FROMR WHERE NAME LIKE“王”第 3 章书面作业1、设学生课程数据库中有三个关系:学生关系 S(S#,SNAME,AGE ,SEX )学习关系 SC(S#,C# ,GRADE)课程关系 C( C#,CNAME)其中 S#、C#、SN
27、AME 、AGE、SEX、GRADE 、CNAME 分别表示学号、课程号、姓名、年龄、性别、成绩和课程名。用 SQL 语句表达下列操作(1)检索选修课程名称为“MATHS”的学生的学号与姓名(2)检索至少学习了课程号为“C1”和“C2 ”的学生的学号(3)检索年龄在 18 到 20 之间(含 18 和 20)的女生的学号、姓名和年龄(4)检索平均成绩超过 80 分的学生学号和平均成绩(5)检索选修了全部课程的学生姓名(6)检索选修了三门课以上的学生的姓名【答案:】 (1)SELECT SNAME,AGEFROM S,SC,CWHERE S.S#=SC.S#AND C.C#=SC.C#AND CNAME= MATHS(2) SELECT S#FROM SCWHERE CNO=C1 AND S# IN( SELECT S#