数据库试题及课后答案(精选五篇)

时间:2019-05-15 10:49:58下载本文作者:会员上传
简介:写写帮文库小编为你整理了多篇相关的《数据库试题及课后答案》,但愿对你工作学习有帮助,当然你在写写帮文库还可以找到更多《数据库试题及课后答案》。

第一篇:数据库试题及课后答案

数据库系统概论习题集

第一章 绪论

一、选择题

1.DBS是采用了数据库技术的计算机系统,DBS是一个集合体,包含数据库、计算机硬件、软件和(C)。

A.系统分析员 B.程序员 C.数据库管理员 D.操作员

2.数据库(DB),数据库系统(DBS)和数据库管理系统(DBMS)之间的关系是(A)。

A.DBS包括DB和DBMS B.DBMS包括DB和DBS

C.DB包括DBS和DBMS D.DBS就是DB,也就是DBMS

3.下面列出的数据库管理技术发展的三个阶段中,没有专门的软件对数据进行管理的是(D)。

I.人工管理阶段

II.文件系统阶段

III.数据库阶段

A.I 和 II B.只有 II

C.II 和 III D.只有 I

4.下列四项中,不属于数据库系统特点的是(C)。

A.数据共享 B.数据完整性 C.数据冗余度高 D.数据独立性高

5.数据库系统的数据独立性体现在(B)。

A.不会因为数据的变化而影响到应用程序

B.不会因为系统数据存储结构与数据逻辑结构的变化而影响应用程序

C.不会因为存储策略的变化而影响存储结构

D.不会因为某些存储结构的变化而影响其他的存储结构

6.描述数据库全体数据的全局逻辑结构和特性的是(A)。

A.模式 B.内模式 C.外模式 D.用户模式

7.要保证数据库的数据独立性,需要修改的是(C)。

A.模式与外模式 B.模式与内模式

C.三层之间的两种映射 D.三层模式

8.要保证数据库的逻辑数据独立性,需要修改的是(A)。

A.模式与外模式的映射 B.模式与内模式之间的映射

C.模式 D.三层模式

9.用户或应用程序看到的那部分局部逻辑结构和特征的描述是(C),它是模式的逻辑子集。

A.模式 B.物理模式 C.子模式 D.内模式

10.下述(D)不是DBA数据库管理员的职责。

A.完整性约束说明 B.定义数据库模式

C.数据库安全 D.数据库管理系统设计

选择题答案:

(1)C(2)A(3)D(4)C(5)B

(6)A(7)C(8)A(9)C(10)D 课后习题

第二章 关系数据库

一、选择题

1.下面的选项不是关系数据库基本特征的是(A)。

A.不同的列应有不同的数据类型

B.不同的列应有不同的列名

C.与行的次序无关

D.与列的次序无关

2.一个关系只有一个(D)。

A.候选码 B.外码 C.超码 D.主码

3.关系模型中,一个码是(C)。

A.可以由多个任意属性组成B.至多由一个属性组成

C.可有多个或者一个其值能够唯一表示该关系模式中任何元组的属性组成D.以上都不是

4.现有如下关系:

患者(患者编号,患者姓名,性别,出生日起,所在单位)

医疗(患者编号,患者姓名,医生编号,医生姓名,诊断日期,诊断结果)

其中,医疗关系中的外码是(A)。

A.患者编号 B.患者姓名

C.患者编号和患者姓名 D.医生编号和患者编号

5.现有一个关系:借阅(书号,书名,库存数,读者号,借期,还期),假如同一本书允许一个读者多次借阅,但不能同时对一种书借多本,则该关系模式的外码是(D)。

A.书号 B.读者号

C.书号+读者号 D.书号+读者号+借期

6.关系模型中实现实体间 N:M 联系是通过增加一个(A)。

A.关系实现 B.属性实现 C.关系或一个属性实现 D.关系和一个属性实现

7.关系代数运算是以(C)为基础的运算。

A.关系运算 B.谓词演算 C.集合运算 D.代数运算

8.关系数据库管理系统应能实现的专门关系运算包括(B)。

A.排序、索引、统计 B.选择、投影、连接

C.关联、更新、排序 D.显示、打印、制表

9.五种基本关系代数运算是(A)。

A.∪ - × σ π

B.∪ - σ π

C.∪ ∩ × σ π

D.∪ ∩ σ π

10.关系代数表达式的优化策略中,首先要做的是(B)。

A.对文件进行预处理

B.尽早执行选择运算

C.执行笛卡尔积运算

D.投影运算

11.关系数据库中的投影操作是指从关系中(B)。

A.抽出特定记录 B.抽出特定字段

C.建立相应的影像 D.建立相应的图形

12.从一个数据库文件中取出满足某个条件的所有记录形成一个新的数据库文件的操作是(C)操作。

A.投影 B.联接 C.选择 D.复制

13.关系代数中的联接操作是由(B)操作组合而成。

A.选择和投影 B.选择和笛卡尔积

C.投影、选择、笛卡尔积 D.投影和笛卡尔积

14.自然联接是构成新关系的有效方法。一般情况下,当对关系R和S是用自然联接

时,要求R和S含有一个或者多个共有的(C)。

A.记录 B.行 C.属性 D.元组

15.假设有关系R和S,在下列的关系运算中,(D)运算不要求:“R和S具有相同的元数,且它们的对应属性的数据类型也相同”。

A.R∩S B.R∪S C.R-S D.R×S

16.假设有关系R和S,关系代数表达式R-(R-S)表示的是(A)。

A.R∩S B.R∪S C.R-S D.R×S

17.下面列出的关系代数表达是中,那些式子能够成立(C)

ⅰ.σf1(σf2(E))= σf1∧f2(E)

ⅱ.E1∞E2 = E2∞E1

ⅲ.(E1∞E2)∞E3 = E1∞(E2∞E3)

ⅳ.σf1(σf2(E))=σf2(σf1(E))

A.全部 B.ⅱ和ⅲ C.没有 D.ⅰ和ⅳ

18.下面四个关系表达式是等价的,是判别它们的执行效率(A)。

E1 =πA(σ B=C ∧ D=E′(R×S))

E2 =πA(σ B=C(R× σD=E′(S))

E3 =πA(R∞B=CσD=E′(S))

E3 =πA(σD=E′(R∞B=C S))

A.E3最快 B.E2最快 C.E4最快 D.E1最快

19.有关系SC(S_ID,C_ID,AGE,SCORE),查找年龄大于22岁的学生的学号和分数,正确的关系代数表达式是(D)。

ⅰ.πS_ID,SCORE(σ age>22(SC))

ⅱ.σ age>22(πS_ID,SCORE(SC))

ⅲ.πS_ID,SCORE(σ age>22(πS_ID,SCORE,AGE(SC)))

A.ⅰ和 ⅱ B.只有ⅱ正确 C.只有 ⅰ正确 D.ⅰ和ⅲ正确

选择题答案:

(1)A(2)D(3)C(4)A(5)D

(6)A(7)C(8)B(9)A(10)B

(11)B(12)C(13)B(14)C(15)D

(16)A(17)C(18)A(19)D 课后习题

5.设有一个SPJ 数据库,包括S,P,J,SPJ 四个关系模式: 1)求供应工程J1 零件的供应商号码SNO: πSno(σSno=‘J1’(SPJ))2)求供应工程J1 零件P1 的供应商号码SNO: πSno(σSno=‘J1’∧Pno=‘P1‘(SPJ))3)求供应工程J1 零件为红色的供应商号码SNO:

πSno(σPno=‘P1‘(σCOLOR=’红‘(P)∞SPJ))4)求没有使用天津供应商生产的红色零件的工程号JNO:

πJno(SPJ)-πJNO(σcity=‘天津’∧Color=‘红‘(S∞SPJ∞P)5)求至少用了供应商S1 所供应的全部零件的工程号JNO: πJno,Pno(SPJ)÷ πPno(σSno=‘S1‘(SPJ))

7.关系代数的基本运算有哪些 ? 如何用这些基本运算来表示其他运算? 答:并、差、笛卡尔积、投影和选择5 种运算为基本的运算。其他3 种运算,即交、连接

除,均可以用这5 种基本运算来表达。第三章 SQL语言

一、选择题

1.SQL语言是(B)的语言,容易学习。

A.过程化 B.非过程化

C.格式化 D.导航式

2.SQL语言的数据操纵语句包括SELECT、INSERT、UPDATE、DELETE等。其中最重要的,也是使用最频繁的语句是(A)。

A.SELECT B.INSERT

C.UPDATE D.DELETE

3.在视图上不能完成的操作是(C)。

A.更新视图 B.查询

C.在视图上定义新的表 D.在视图上定义新的视图

4.SQL语言集数据查询、数据操纵、数据定义和数据控制功能于一体,其中,CREATE、DROP、ALTER语句是实现哪种功能(C)。

A.数据查询 B.数据操纵

C.数据定义 D.数据控制

5.SQL语言中,删除一个视图的命令是(B)。

A.DELETE

B.DROP

C.CLEAR

D.REMOVE

6.在SQL语言中的视图VIEW是数据库的(A)。

A.外模式 B.模式 C.内模式 D.存储模式

7.下列的SQL语句中,(D)不是数据定义语句。

A.CREATE TABLE B.DROP VIEW

C.CREATE VIEW D.GRANT

8.若要撤销数据库中已经存在的表S,可用(C)。

A.DELETE TABLE S B.DELETE S

C.DROP TABLE S D.DROP S

9.若要在基本表S中增加一列CN(课程名),可用(C)。

A.ADD TABLE S(CN CHAR(8))

B.ADD TABLE S ALTER CN CHAR(8)

C.ALTER TABLE S ADD(CN CHAR(8))

D.ALTER TABLE S(ADD CN CHAR(8))

10.学生关系模式 S(S#,Sname,Sex,Age),S的属性分别表示学生的学号、姓名、性别、年龄。要在表S中删除一个属性“年龄”,可选用的SQL语句是(B)。

A.DELETE Age from S

B.ALTER TABLE S DROP Age

C.UPDATE S Age

D.ALTER TABLE S ‘Age’

11.有关系S(S#,SNAME,SAGE),C(C#,CNAME),SC(S#,C#,GRADE)。其中S#是学生号,SNAME是学生姓名,SAGE是学生年龄,C#是课程号,CNAME是

课程名称。要查询选修“ACCESS”课的年龄不小于20的全体学生姓名的SQL语句是SELECT SNAME FROM S,C,SC WHERE子句。这里的WHERE子句的内容是(A)。

A.S.S# = SC.S# and C.C# = SC.C# and SAGE>=20 and CNAME=‘ACCESS’

B.S.S# = SC.S# and C.C# = SC.C# and SAGE in>=20 and CNAME in ‘ACCESS’

C.SAGE in>=20 and CNAME in ‘ACCESS’

D.SAGE>=20 and CNAME=’ ACCESS’

12.设关系数据库中一个表S的结构为S(SN,CN,grade),其中SN为学生名,CN为课程名,二者均为字符型;grade为成绩,数值型,取值范围0-100。若要把“张二的化学成绩80分”插入S中,则可用(D)。

A.ADD

INTO S

VALUES(’张二’,’化学’,’80’)

B.INSERT

INTO S

VALUES(’张二’,’化学’,’80’)

C.ADD

INTO S

VALUES(’张二’,’化学’,80)

D.INSERT

INTO S

VALUES(’张二’,’化学’,80)

13.设关系数据库中一个表S的结构为:S(SN,CN,grade),其中SN为学生名,CN为课程名,二者均为字符型;grade为成绩,数值型,取值范围0-100。若要更正王二的化学成绩为85分,则可用(A)。

A.UPDATE S

SET grade=85

WHERE SN=’王二’ AND CN=’化学’

B.UPDATE S

SET grade=’85’

WHERE SN=’王二’ AND CN=’化学’

C.UPDATE grade=85

WHERE SN=’王二’ AND CN=’化学’

D.UPDATE grade=’85’

WHERE SN=’王二’ AND CN=’化学’

14.在SQL语言中,子查询是(D)。

A.返回单表中数据子集的查询语言

B.选取多表中字段子集的查询语句

C.选取单表中字段子集的查询语句

D.嵌入到另一个查询语句之中的查询语句

15.SQL是一种(C)语言。

A.高级算法 B.人工智能

C.关系数据库 D.函数型

16.有关系S(S#,SNAME,SEX),C(C#,CNAME),SC(S#,C#,GRADE)。其中S#是学生号,SNAME是学生姓名,SEX是性别,C#是课程号,CNAME是课程名

称。要查询选修“数据库”课的全体男生姓名的SQL语句是SELECT SNAME FROM S,C,SC WHERE子句。这里的WHERE子句的内容是(A)。

A.S.S# = SC.S# and C.C# = SC.C# and SEX=’男’ and CNAME=’数据库’

B.S.S# = SC.S# and C.C# = SC.C# and SEX in’男’and CNAME in’数据库’

C.SEX ’男’ and CNAME ’ 数据库’

D.S.SEX=’男’ and CNAME=’ 数据库’

17.若用如下的SQL语句创建了一个表SC:

CREATE TABLE SC(S# CHAR(6)NOT NULL,C# CHAR(3)NOT NULL,SCORE INTEGER,NOTE CHAR(20));向SC表插入如下行时,(B)行可以被插入。

A.(’201009’,’111’,60,必修)

B.(’200823’,’101’,NULL,NULL)

C.(NULL,’103’,80,’选修’)

D.(’201132’,NULL,86,’ ’)

18.假设学生关系S(S#,SNAME,SEX),课程关系C(C#,CNAME),学生选课关系SC(S#,C#,GRADE)。要查询选修“Computer”课的男生姓名,将涉及到关系(D)。

A.S B.S,SC C.C,SC D.S,C,SC

选择题答案:

(1)B(2)A(3)C(4)C(5)B

(6)A(7)D(8)C(9)C(10)B

(11)A(12)D(13)A(14)D(15)C

(16)A(17)B(18)D 课后习题

3.用SQL语句建立第2章习题5中的四个表。

第四章 数据库安全性

一、选择题

1.以下(D)不属于实现数据库系统安全性的主要技术和方法。

A.存取控制技术 B.视图技术

C.审计技术 D.出入机房登记和加锁

2. SQL中的视图提高了数据库系统的(D)。

A.完整性 B.并发控制

C.隔离性 D.安全性

3. SQL语言的GRANT和REMOVE语句主要是用来维护数据库的(C)。

A.完整性 B.可靠性

C.安全性 D.一致性

4.在数据库的安全性控制中,授权的数据对象的(A),授权子系统就越灵活。

A.范围越小 B.约束越细致

C.范围越大 D.约束范围大

选择题答案:

(1)D(2)D(3)C(4)A

5.试述实现数据库安全性控制的常用方法和技术。

答: 实现数据库安全性控制的常用方法和技术有:

1)用户标识和鉴别:该方法由系统提供一定的方式让用户标识自己的名字或身份。每次用户要求进入系统时,由系统进行核对,通过鉴定后才提供系统的使用权。

2)存取控制:通过用户权限定义和合法权检查确保只有合法权限的用户访问数据库,所有未被授权的人员无法存取数据。例如C2级中的自主存取控制(DAC),B1级中的强制存取控制(MAC);

3)视图机制:为不同的用户定义视图,通过视图机制把要保密的数据对无权存取的用户隐藏起来,从而自动地对数据提供一定程度的安全保护。

4)审计:建立审计日志,把用户对数据库的所有操作自动记录下来放入审计日志中,DBA可以利用审计跟踪的信息,重现导致数据库现有状况的一系列事件,找出非法存取数据的人、时间和内容等。

5)数据加密:对存储和传输的数据进行加密处理,从而使得不知道解密算法的人无法获知数据的内容。

具体内容请参见《概论》9.2。

6.什么是数据库中的自主存取控制方法和强制存取控制方法?

答: 自主存取控制方法:定义各个用户对不同数据对象的存取权限。当用户对数据库访问时首先检查用户的存取权限。防止不合法用户对数据库的存取。

强制存取控制方法:每一个数据对象被(强制地)标以一定的密级,每一个用户也被(强制地)授予某一个级别的许可证。系统规定只有具有某一许可证级别的用户才能存取某一个密级的数据对象。

*解析:自主存取控制中自主的含义是:用户可以将自己拥有的存取权限“自主”地授予别人。即用户具有一定的“自主”权。

7.SQL语言中提供了哪些数据控制(自主存取控制)的语句?请试举几例说明它们的使用方法。

答:

SQL中 的自主存取控制是通过GRANT 语句和 REVOKE 语句来实现的。如:

GRANT SELECT,INSERT ON Student TO 王平WITH GRANT OPTION;

就将Student表的SELECT和INSERT权限授予了用户王平,后面的“WITH GRANT OPTION”子句表示用户王平同时也获得了“授权”的权限,即可以把得到的权限继续授予其他用户。

REVOKE INSERT ON Student FROM 王平CASCADE;

就将Student表 的INSERT权限从用户王平处收回,选项 CASCADE 表示,如果用户王平将 Student 的 INSERT 权限又转授给了其他用户,那么这些权限也将从其他用户处收回。

10.为什么强制存取控制提供了更高级别的数据库安全性?

答:

强制存取控制(MAC)是对数据本身进行密级标记,无论数据如何复制,标记与数据是一个不可分的整体,只有符合密级标记要求的用户才可以操纵数据,从而提供了更高级别的安全性。

11.理解并解释MAC机制中主体、客体、敏感度标记的含义。

答:

主体是系统中的活动实体,既包括DBMS所管理的实际用户,也包括代表用户的各进程。

客体是系统中的被动实体,是受主体操纵的,包括文件、基表、索引、视图等。

对于主体和客体,DBMS为它们每个实例(值)指派一个敏感度标记(Label)。敏感度标记被分成若干级别,例如绝密(Top Secret)、机密(Secret)、可信(Confidential)、公开(Public)等。主体的敏感度标记称为许可证级别(Clearance Level),客体的敏感度标记称为密级(Classification Level)。

13.什么是数据库的审计功能,为什么要提供审计功能?

答:

审计功能是指DBMS的审计模块在用户对数据库执行操作的同时把所有操作自动记录到系统的审计日志中。

因为任何系统的安全保护措施都不是完美无缺的,蓄意盗窃破坏数据的人总可能存在。利用数据库的审计功能,DBA可以根据审计跟踪的信息,重现导致数据库现有状况的一系列事件,找出非法存取数据的人、时间和内容等。

第五章 数据库完整性

一、选择题

1.完整性检查和控制的防范对象(AC),防止它们进入数据库。安全性控制的防范对象是(BD),防止他们对数据库数据的存取。

A.不合语义的数据 B.非法用户

C.不正确的数据 D.非法操作

2.下述哪个是SQL语言中的数据控制命令(A)。

A.GRANT B.COMMIT

C.UPDATE D.SELECT

3.下述SQL语言中的权限,哪一个允许用户定义新关系时,引用其他关系的主码作为外码(C)。

A.INSERT B.DELETE

C.REFERENCES D.SELECT

选择题答案:

(1)A C B D(2)A(3)C 课后习题

6.假设有下面两个关系模式:

职工(职工号,姓名,年龄,职务,工资,部门号),其中职工号为主码;

部门(部门号,名称,经理名,电话),其中部门号为主码;

用SQL语言定义这两个关系模式,要求在模式中完成以下完整性约束条件的定义:

定义每个模式的主码;定义参照完整性;定义职工年龄不得超过60岁。

CREATE TABLE DEPT

(Deptno NUMBER(2),Deptname VARCHAR(10),Manager VARCHAR(10),PhoneNumber Char(12)

CONSTRAINT PK_SC PRIMARY KEY(Deptno));

CREATE TABLE EMP

(Empno NUMBER(4),Ename VARCHAR(10),Age NUMBER(2),CONSTRAINT C1 CHECK(Age《=60),Job VARCHAR(9),Sal NUMBER(7,2),Deptno NUMBER(2),CONSTRAINT FK_DEPTNO

FOREIGN KEY(Deptno)

REFERENCES DEPT(Deptno));

第六章 关系数据理论

一、选择题

1.为了设计出性能较优的关系模式,必须进行规范化,规范化主要的理论依据是(A)。

A.关系规范化理论 B.关系代数理论

C.数理逻辑 D.关系运算理论

2.规范化理论是关系数据库进行逻辑设计的理论依据,根据这个理论,关系数据库中的关系必须满足:每一个属性都是(B)。

A.长度不变的 B.不可分解的C.互相关联的 D.互不相关的

3.已知关系模式R(A,B,C,D,E)及其上的函数相关性集合F={A→D,B→C,E→A },该关系模式的候选关键字是(B)。

A.AB B.BE

C.CD D.DE

4.设学生关系S(SNO,SNAME,SSEX,SAGE,SDPART)的主键为SNO,学生选课关系SC(SNO,CNO,SCORE)的主键为SNO和CNO,则关系R(SNO,CNO,SSEX,SAGE,SDPART,SCORE)的主键为SNO和CNO,其满足(A)。

A.1NF B.2NF

C.3NF D.BCNF

5.设有关系模式W(C,P,S,G,T,R),其中各属性的含义是:C表示课程,P表示教师,S表示学生,G表示成绩,T表示时间,R表示教室,根据语义有如下数据依赖集:D={ C→P,(S,C)→G,(T,R)→C,(T,P)→R,(T,S)→R },关系模式W的一个关键字是(D)。

A.(S,C)B.(T,R)

C.(T,P)D.(T,S)

6.关系模式中,满足2NF的模式(B)。

A.可能是1NF B.必定是1NF

C.必定是3NF D.必定是BCNF

7.关系模式R中的属性全是主属性,则R的最高范式必定是(C)。

A.1NF B.2NF

C.3NF D.BCNF

8.消除了部分函数依赖的1NF的关系模式,必定是(B)。

A.1NF B.2NF

C.3NF D.BCNF

9.如果A->B ,那么属性A和属性B的联系是(B)。

A.一对多 B.多对一

C.多对多 D.以上都不是

10.关系模式的候选关键字可以有1个或多个,而主关键字有(C)。

A.多个 B.0个

C.1个 D.1个或多个

11.候选关键字的属性可以有(D)。

A.多个 B.0个

C.1个 D.1个或多个

12.关系模式的任何属性(A)。

A.不可再分 B.可以再分

C.命名在关系模式上可以不唯一 D.以上都不是

13.设有关系模式W(C,P,S,G,T,R),其中各属性的含义是:C表示课程,P表示教师,S表示学生,G表示成绩,T表示时间,R表示教室,根据语义有如下数据依赖集:D={ C→P,(S,C)→G,(T,R)→C,(T,P)→R,(T,S)→R },若将关系模式W分解为三个关系模式W1(C,P),W2(S,C,G),W2(S,T,R,C),则W1的规范化程序最高达到(D)。

A.1NF B.2NF

C.3NF D.BCNF

14.在关系数据库中,任何二元关系模式的最高范式必定是(D)。

A.1NF B.2NF

C.3NF D.BCNF

15.在关系规范式中,分解关系的基本原则是(B)。

I.实现无损连接

II.分解后的关系相互独立

III.保持原有的依赖关系

A.Ⅰ和Ⅱ B.Ⅰ和Ⅲ

C.Ⅰ D.Ⅱ

16.不能使一个关系从第一范式转化为第二范式的条件是(B)。

A.每一个非属性都完全函数依赖主属性

B.每一个非属性都部分函数依赖主属性

C.在一个关系中没有非属性存在D.主键由一个属性构成

17.任何一个满足2NF但不满足3NF的关系模式都不存在(D)。

A.主属性对键的部分依赖

B.非主属性对键的部分依赖

C.主属性对键的传递依赖

D.非主属性对键的传递依赖

18.设数据库关系模式R=(A,B,C,D,E),有下列函数依赖:A→BC,D→E,C→D;下述对R的分解中,哪些分解是R的无损连接分解(B)。

I.(A,B,C)(C,D,E)

II.(A,B)(A,C,D,E)

III.(A,C)(B,C,D,E)

IV.(A,B)(C,D,E)

A.只有Ⅳ B.Ⅰ和Ⅱ C.Ⅰ、Ⅱ和Ⅲ D.都不是

19.设U是所有属性的集合,X、Y、Z都是U的子集,且Z=U-X-Y。下面关于多值依赖的叙述中,不正确的是(C)。

A.若X→→Y,则X→→Z

B.若X→Y,则X→→Y

C.若X→→Y,且Y′∈Y,则X→→Y′

D.若Z=∮,则X→→Y

20.若关系模式R(U,F)属于3NF,则(C)。

A.一定属于BCNF

B.消除了插入的删除异常

C.仍存在一定的插入和删除异常

D.属于BCNF且消除了插入和删除异常

21.下列说法不正确的是(C)。

A.任何一个包含两个属性的关系模式一定满足3NF

B.任何一个包含两个属性的关系模式一定满足BCNF

C.任何一个包含三个属性的关系模式一定满足3NF

D.任何一个关系模式都一定有码

22.设关系模式R(A,B,C),F是R上成立的FD集,F={B→C},则分解P={AB,BC}相对于F(A)。

A.是无损联接,也是保持FD的分解

B.是无损联接,也不保持FD的分解

C.不是无损联接,但保持FD的分解

D.既不是无损联接,也不保持FD的分解

23.关系数据库规范化是为了解决关系数据库中(A)的问题而引入的。

A.插入、删除和数据冗余

B.提高查询速度

C.减少数据操作的复杂性

D.保证数据的安全性和完整性

24.关系的规范化中,各个范式之间的关系是(B)。

A.1NF∈2NF∈3NF

B.3NF∈2NF∈1NF

C.1NF=2NF=3NF

D.1NF∈2NF∈BCNF∈3NF

25.数据库中的冗余数据是指可(D)的数据。

A.容易产生错误

B.容易产生冲突

C.无关紧要

D.由基本数据导出

26.学生表(id,name,sex,age,depart_id,depart_name),存在函数依赖是id→name,sex,age,depart_id;dept_id→dept_name,其满足(B)。

A.1NF B.2NF

C.3NF D.BCNF

27.设有关系模式R(S,D,M),其函数依赖集:F={S→D,D→M},则关系模式R的规范化程度最高达到(B)。

A.1NF B.2NF

C.3NF D.BCNF

28.设有关系模式R(A,B,C,D),其数据依赖集:F={(A,B)→C,C→D},则关系模式R的规范化程度最高达到(B)。

A.1NF B.2NF

C.3NF D.BCNF

29.下列关于函数依赖的叙述中,哪一条是不正确的(B)。

A.由X→Y,Y→Z,则X→YZ

B.由X→YZ,则X→Y,Y→Z

C.由X→Y,WY→Z,则XW→Z

D.由X→Y,Z∈Y,则X→Z

30.X→Y,当下列哪一条成立时,称为平凡的函数依赖(B)。

A.X∈Y B.Y∈X

C.X∩Y=∮ D.X∩Y≠∮

31.关系数据库的规范化理论指出:关系数据库中的关系应该满足一定的要求,最起码的要求是达到1NF,即满足(D)。

A.每个非主键属性都完全依赖于主键属性

B.主键属性唯一标识关系中的元组

C.关系中的元组不可重复

D.每个属性都是不可分解的

32.根据关系数据库规范化理论,关系数据库中的关系要满足第一范式,部门(部门号,部门名,部门成员,部门总经理)关系中,因哪个属性而使它不满足第一范式(B)。

A.部门总经理 B.部门成员 C.部门名 D.部门号

33.有关系模式A(C,T,H,R,S),其中各属性的含义是:

C:课程 T:教员 H:上课时间 R:教室 S:学生

根据语义有如下函数依赖集:

F={C→T,(H,R)→C,(H,T)RC,(H,S)→R}

(1)关系模式A的码是(B)。

A.C B.(H,S)C.(H,R)D.(H,T)

(2)关系模式A的规范化程度最高达到(B)。

A.1NF B.2NF C.3NF D.BCNF

(3)现将关系模式A分解为两个关系模式A1(C,T),A2(H,R,S),则其中A1的规范化程度达到(D)。

A.1NF B.2NF C.3NF D.BCNF

选择题答案:

(1)A(2)B(3)B(4)A(5)D

(6)B(7)C(8)B(9)B(10)C

(11)D(12)A(13)D(14)D(15)B

(16)B(17)D(18)B(19)C(20)C

(21)C(22)A(23)A(24)A(25)D

(26)B(27)B(28)B(29)B(30)B

(31)D(32)B(33)B B D

2.建立一个关于系、学生、班级、学会等诸信息的关系数据库。

描述学生的属性有:学号、姓名、出生年月、系名、班号、宿舍区。

描述班级的属性有:班号、专业名、系名、人数、入校年份。

描述系的属性有:系名、系号、系办公室地点、人数。

描述学会的属性有:学会名、成立年份、地点、人数。

有关语义如下:一个系有若干专业,每个专业每年只招一个班,每个班有若干学生。一个系的学生住在同一宿舍区。每个学生可参加若干学会,每个学会有若干学生。学生参加某学会有一个入会年份。

请给出关系模式,写出每个关系模式的极小函数依赖集,指出是否存在传递函数依赖,对于函数依赖左部是多属性的情况讨论函数依赖是完全函数依赖,还是部分函数依赖。

指出各关系的候选码、外部码,有没有全码存在?

答:

关系模式: 学生S(S#,SN,SB,DN,C#,SA)

班级C(C#,CS,DN,CNUM,CDATE)

系 D(D#,DN,DA,DNUM)

学会P(PN,DATE1,PA,PNUM)

学生--学会SP(S#,PN,DATE2)

其中,S#—学号,SN—姓名,SB—出生年月,SA—宿舍区

C#—班号,CS—专业名,CNUM—班级人数,CDATE—入校年份

D#—系号,DN—系名,DA—系办公室地点,DNUM—系人数

PN—学会名,DATE1—成立年月,PA—地点,PNUM—学会人数,DATE2—入会年份

每个关系模式的极小函数依赖集:

S:S#→SN,S#→SB,S#→C#,C#→DN,DN→SA

C:C#→CS,C#→CNUM,C#→CDATE,CS→DN,(CS,CDATE)→C#

D:D#→DN,DN→D#,D#→DA,D#→DNUM

P:PN→DATE1,PN→PA,PN→PNUM

SP:(S#,PN)→DATE2

S中存在传递函数依赖: S#→DN, S#→SA, C#→SA

C中存在传递函数依赖:C#→DN

(S#,PN)→DATE2 和(CS,CDATE)→C# 均为SP中的函数依赖,是完全函数依赖

关系 候选码 外部码 全码

S S# C#,DN 无

C C#,(CS,CDATE)DN 无

D D#和DN 无 无

P PN 无 无

SP(S#,PN)S#,PN 无

第七章 数据库设计

一、选择题

1.数据流程图是用于描述结构化方法中(D)阶段的工具。

A.概要设计 B.可行性分析

C.程序编码 D.需求分析

2.数据库设计中,用E-R图赖描述信息结构但不涉及信息在计算机中的表示,这是数据库设计的(C)。

A.需求分析阶段 B.逻辑设计阶段

C.概念设计阶段 D.物理设计阶段

3.在数据库设计中,将E-R图转换成关系数据模型的过程属于(B)。

A.需求分析阶段 B.逻辑设计阶段

C.概念设计阶段 D.物理设计阶段

4.子模式DDL是用来描述(B)。

A.数据库的总体逻辑结构 B.数据库的局部逻辑结构

C.数据库的物理存储结构 D.数据库的概念结构

5.数据库设计的概念设计阶段,表示概念结构的常用方法和描述工具是(C)。

A.层次分析法和层次结构图

B.数据流程分析法和数据流程图

C.实体联系法和实体联系图

D.结构分析法和模块结构图

6.在E-R模型向关系模型转换时,M:N的联系转换为关系模式时,其关键字是(C)。

A.M端实体的关键字

B.N端实体的关键字

C.M、N端实体的关键字组合D.重新选取其他属性

7.某学校规定,每一个班级最多有50名学生,至少有10名学生;每一名学生必须属于一个班级。在班级与学生实体的联系中,学生实体的基数是(B)。

A.(0,1)B.(1,1)

C.(1,10)D.(10,50)

8.在关系数据库设计中,设计关系模式是数据库设计中(A)阶段的任务。

A.逻辑设计阶段 B.概念设计阶段

C.物理设计阶段 D.需求分析阶段

9.关系数据库的规范化理论主要解决的问题是(A)。

A.如何构造合适的数据逻辑结构

B.如何构造合适的数据物理结构

C.如何构造合适的应用程序界面

D.如何控制不同用户的数据操作权限

10.数据库设计可划分为七个阶段,每个阶段都有自己的设计内容,“为哪些关系,在哪些属性上、键什么样的索引”这一设计内容应该属于(C)设计阶段。

A.概念设计 B.逻辑设计

C.物理设计 D.全局设计

11.假设设计数据库性能用“开销”,即时间、空间及可能的费用来衡量,则在数据库应用系统生存期中存在很多开销。其中,对物理设计者来说,主要考虑的是(C)。

A.规划开销 B.设计开销

C.操作开销 D.维护开销

12.数据库物理设计完成后,进入数据库实施阶段,下述工作中,(D)一般不属于实

施阶段的工作。

A.建立库结构 B.系统调试

C.加载数据 D.扩充功能

13.从ER图导出关系模型时,如果实体间的联系是M:N的,下列说法中正确的是(C)。

A.将N方关键字和联系的属性纳入M方的属性中

B.将M方关键字和联系的属性纳入N方的属性中

C.增加一个关系表示联系,其中纳入M方和N方的关键字

D.在M方属性和N方属性中均增加一个表示级别的属性

14.在ER模型中,如果有3个不同的实体集,3个M:N联系,根据ER模型转换为关系模型的规则,转换为关系的数目是(C)。

A.4 B.5

C.6 D.7

选择题答案:

(1)D(2)C(3)B(4)B(5)C

(6)C(7)B(8)A(9)A(10)C

(11)C(12)D(13)C(14)C 课后习题

6.数据字典的内容和作用是什么?

答:

数据字典是系统中各类数据描述的集合。数据字典的内容通常包括:数据项、数据结构、数据流、数据存储、处理过程五个部分

其中数据项是数据的最小组成单位,若干个数据项可以组成一个数据结构。数据字典通过对数据项和数据结构的定义来描述数据流、数据存储的逻辑内容。

数据字典的作用:

数据字典是关于数据库中数据的描述,在需求分析阶段建立,是下一步进行概念设计的基础,并在数据库设计过程中不断修改、充实、完善。

(注意,数据库设计阶段形成的数据字典与后面讲到的数据字典不同,后者是DBMS关于数据库中数据的描述,当然两者是有联系的)。

第九章 关系系统及其优化

一、选择题

1.概念模型是现实世界的第一层抽象,这一类最著名的模型是(D)。

A.层次模型 B.关系模型 C.网状模型 D.实体-关系模型

2.区分不同实体的依据是(B)。

A.名称 B.属性 C.对象 D.概念

3.关系数据模型是目前最重要的一种数据模型,它的三个要素分别为(B)。

A.实体完整、参照完整、用户自定义完整

B.数据结构、关系操作、完整性约束

C.数据增加、数据修改、数据查询

D.外模式、模式、内模式

4.在(A)中一个结点可以有多个双亲,节点之间可以有多种联系。

A.网状模型 B.关系模型

C.层次模型 D.以上都有

5.(B)的存取路径对用户透明,从而具有更高的数据独立性、更好的安全保密性,也简化了程序员的工作和数据库开发建立的工作。

A.网状模型 B.关系模型

D.层次模型 D.以上都有

6.在关系数据库中,要求基本关系中所有的主属性上不能有空值,其遵守的约束规则是(C)。

A.数据依赖完整性规则 B.用户定义完整性规则

C.实体完整性规则 D.域完整性规则

选择题答案:

(1)D(2)B(3)B(4)A(5)B(6)C 课后习题

第十章 数据库恢复技术

一、选择题

1.一个事务的执行,要么全部完成,要么全部不做,一个事务中对数据库的所有操作都是一个不可分割的操作序列的属性是(A)。

A.原子性 B.一致性

C.独立性 D.持久性

2.表示两个或多个事务可以同时运行而不互相影响的是(C)。

A.原子性 B.一致性

C.独立性 D.持久性

3.事务的持续性是指(B)

A.事务中包括的所有操作要么都做,要么都不做。

B.事务一旦提交,对数据库的改变是永久的。

C.一个事务内部的操作对并发的其他事务是隔离的。

D.事务必须是使数据库从一个一致性状态变到另一个一致性状态。

4.SQL语言中的COMMIT语句的主要作用是(C)。

A.结束程序 B.返回系统

C.提交事务 D.存储数据

5.SQL语言中用(B)语句实现事务的回滚

A.CREATE TABLE B.ROLLBACK

C.GRANT和REVOKE D.COMMIT

6. 若系统在运行过程中,由于某种硬件故障,使存储在外存上的数据部分损失或全部损失,这种情况称为(A)。

A.介质故障 B.运行故障

C.系统故障 D.事务故障

7. 在DBMS中实现事务持久性的子系统是(D)。

A.安全管理子系统 B.完整性管理子系统

C.并发控制子系统 D.恢复管理子系统

8.后援副本的作用是(C)。

A.保障安全性 B.一致性控制

C.故障后的恢复 D.数据的转储

9. 事务日志用于保存(C)。

A.程序运行过程 B.程序的执行结果

C.对数据的更新操作 D.数据操作

10. 数据库恢复的基础是利用转储的冗余数据。这些转储的冗余数据包括(C)。

A.数据字典、应用程序、审计档案、数据库后备副本

B.数据字典、应用程序、审计档案、日志文件

C.日志文件、数据库后备副本

D.数据字典、应用程序、数据库后备副本

选择题答案:

(1)A(2)C(3)B(4)C(5)B

(6)A(7)D(8)C(9)C(10)C

第十一章 数据库并发控制

一、选择题

1. 为了防止一个用户的工作不适当地影响另一个用户,应该采取(D)。

A.完整性控制 B.访问控制

C.安全性控制 D.并发控制

2.解决并发操作带来的数据不一致问题普遍采用(A)技术。

A.封锁 B.存取控制

C.恢复 D.协商

3. 下列不属于并发操作带来的问题是(C)。

A.丢失修改 B.不可重复读

C.死锁 D.脏读

4. DBMS普遍采用(C)方法来保证调度的正确性。

A.索引 B.授权

C.封锁 D.日志

5.事务T在修改数据R之前必须先对其加X锁,直到事务结束才释放,这是(A)。

A.一级封锁协议 B.二级封锁协议

C.三级封锁协议 D.零级封锁协议

6. 如果事务T获得了数据项Q上的排他锁,则T对Q(C)。

A.只能读不能写 B.只能写不能读

C.既可读又可写 D.不能读也不能写

7.设事务T1和T2,对数据库中地数据A进行操作,可能有如下几种情况,请问哪一种不会发生冲突操作(D)。

A.T1正在写A,T2要读A

B.T1正在写A,T2也要写A

C.T1正在读A,T2要写A

D.T1正在读A,T2也要读A

8.如果有两个事务,同时对数据库中同一数据进行操作,不会引起冲突的操作是(D)。

A.一个是DELETE,一个是SELECT

B.一个是SELECT,一个是DELETE

C.两个都是UPDATE

D.两个都是SELECT

9. 在数据库系统中,死锁属于(B)。

A.系统故障 B.事务故障

C.介质故障 D.程序故障

选择题答案:

(1)D(2)A(3)C(4)C(5)A

(6)C(7)D(8)D(9)B

第二篇:数据库试题及答案_

笔试样卷一

参考答案

一、简答题(25分)

1.数据库阶段数据管理的主要特点是什么? 2.

解释DB、DBMS、DBS三个概念?

3.什么是物理数据独立性和逻辑数据独立性? 4.

试说明DBMS的主要功能?

5.在ER模型转换为关系模型时,联系类型要根据不同的情况作不同的处理,试说明之。

二、计算题(20分)

1.设有关系R和S R: S:

A B C A B C 3 6 7 3 4 5 2 5 7 7 2 3 7 3 4 4 4 3 列表计算R∪S、R-S、R×S、π3,2(S)、δB<5(R)。(5分)2.

设有三个关系

S(SNO, SNAME, AGE, SEX, SDEPT)SC(SNO, CNO, GRANDE)C(CNO, CNAME, CDEPT, TNAME)试用关系代数表达式表示下列查询

(1)检索LIU老师所授课程的课程号、课程名(2)检索年龄大于23岁的男学生的学号和姓名

(3)检索学号为S3的学生所学课程的课程名和认课教师姓名(4)检索WANG同学不学的课程的课程号

(5)检索至少选修了两门课程的学生的学号(10分)

三、设有三个基本表(45分)

S(SNO, SNAME, AGE, SEX, SDEPT)SC(SNO, CNO, GRANDE)C(CNO, CNAME, CDEPT, TNAME)1.

试用T-SQL的查询语句表达下列查询(1)检索LIU老师所授课程的课程号、课程名(2)检索年龄大于23岁的男学生的学号和姓名

(3)检索学号为S3的学生所学课程的课程名和认课教师姓名(4)检索WANG同学不学的课程的课程号

(5)检索至少选修了两门课程的学生的学号(10分)2.

试用T-SQL的查询语句表达下列查询(1)统计有学生选修的课程的门数(2)求选修C4课程的学生的年龄

(3)求LIU老师所授课程的每门课程的学生的平均成绩(4)统计每门课程的学生选修人数

(5)求年龄大于所有女同学年龄的男学生的姓名和年龄(10分)3.

试用T-SQL更新语句完成下列更新操作

(1)往表S中插入一个学生资料(‘S9’, ‘WU’, 18)

(2)在表S中检索每一门课程成绩都大于等于80分的学生的学号、姓名、性别,把检索结果插入另一个已存在的表STU(SNO, SNAME, SEX)(3)删除SC表中WANG同学的选课资料(4)把低于总平均分的女同学的成绩提高5%(5)把表SC中C4课程的成绩提高5%(10分)

四、设有关系模式R(ABCD),R上的FD集F={ AB→CD, A→D},试说明R不是2NF的理由,并把R分解成2NF模式集。(10分)

数据库应用笔试样卷一参考答案

一、简答题(25分)

1.采用数据模型表示复杂的数据结构;有较高的数据独立性;为用户提供了方便的用户接口;提供数据控制功能;增加了系统的灵活性。

2.DB(数据库):存储在计算机内有组织的、统一管理的相关数据的集合。DBMS(数据库管理系统):是位于用户与操作系统之间的数据管理软件。

DBS(数据库系统):是实现有组织的、动态的存储大量关联数据,以方便用户访问的计算机硬件、软件和株距资源组成的计算机系统。

3.物理数据独立性:内模式的修改,只需对模式/内模式映象做相应修改,而不需修改概念模式。逻辑数据独立性:概念模式的修改,只需对外模式/模式映象做相应修改,而不需修改外模式。4.DBMS的主要功能:

数据定义(DDL):三级结构、两级映象、完整性约束等。数据操纵(DML):检索、更新。

数据保护:数据恢复、并发控制、完整性控制、安全性控制等。数据维护:数据载入、转换、存储、、性能监控等。

数据字典(DD):存储三级结构定义的数据库称为DD,即系统数据库。5.实体:实体类型→关系模式。联系:

1∶1:将联系臵入任一端实体,并加入另一端实体主键为外键。1∶N:将联系臵入多端实体,并加入一端实体主键为外键。M∶N:建立新关系模式,主键为两端实体的主键,并为外键。

二、计算题(20分)1.R∪S: A B C 3 6 7 2 5 7 7 3 4 4 4 3 4 5 7 2 3 R-S: A B C 3 6 7 2 5 7 7 3 4 4 4 3 R×S

A B C π3,2(S): C B 5 3 4 2 δB<5(R): A B C 7 3 4 4 4 3 2.(1)∏cno,cname(σTNAME=’ LIU’(C))(2)∏sno,sname(σage=23 ∧sex=’ 男’(S))(3)∏cname,tname(σsno=’s3’(S)∞SC∞C)(4)∏cno(C)-∏cno(σsname=’WANG’(SC∞S))(5)∏sno(σ1=4∧2<>5(SCXSC))

三、(45分)1.(1)SELECT CNO,CNAME FROM C WHERE TNAME=’ LIU’

(2)SELECT SNO,SNAME FROM S WHERE AGE>23 AND sex=’ 男’(3)SELECT C.CNO, TNAME FROM S,SC,C WHERE SNO=’S3’ AND C.CNO=SC.CNO=’c03’ AND S.SNO=SC.SNO(4)select cno from c where not exists(select cno from sc where c.cno=sc.cno and sname='WANG')(5)select sc1.sno from sc as sc1,sc as sc2 where sc1.sno=sc2.sno and sc1.cno<>sc2.cno 2.(1)select ,count(*)as num from sc group by cno(2)SELECT SNO,AGE FROM S,SC WHERE S.SNO=SC.SNO AND CNO=’C4’

(3)select cno, avg(score)from c,sc WHERE TNAME=’ LIU’ AND C.CNO=SC.CNO group by cno(4)select cno,count(*)from sc(5)select sname,age from s where SEX='男' and age>all(select age from s where sex='女')3.(1)INSERT INTO S(sno, sname, age)VALUE(‘S9’, ‘WU’, 18)

(2)select sno,sname,.seg into stu from s where score>=80 and s.sno=sc.sno(3)delete from sc where sc.sno=(select sno from s where sname=’wang’ and s.sno=sc.sno)

(4)update sc set score=score*(1+0.05)from s,sc where sex=’ 女’ and s.sno=sc.sno and score<(select avg(score)from sc)(5)update sc set score=score*(1+0.05)from where cno=’c4’

四、(10分)

设有关系模式R(ABCD),R上的FD集F={ AB→CD, A→D},试说明R不是2NF的理由,并把R分解成2NF模式集。(10分)

1、侯选键为AB

2、由AB→CD 可知AB→C,AB→D 又由于A→D

故D局部依赖于侯选键AB 所以R不是2NF

3、R1(AB,C)R2(A,D)

笔试样卷二

参考答案

一、选择题(10X2=20分)

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.SQL Server系统数据库不包括

a)master b)tempdb c)student d)model 7.

SQL Server中,数据库主数据文件扩展名为

a)ldf b)mdf c)ndf d)dbf 8.

SQL Server中,索引类型包括

a)聚集索引和非聚集索引 b)主索引和次索引 c)单索引和复合索引 d)内索引和外索引 9.

SQL的数据操纵命令是

a)select、insert、delete、update b)create、select、insert、delete c)create、insert、delete、update d)select、insert、delete、alter 10.SQL Server系统的触发器包括

a)select、insert、delete b)insert、delete、update c)select、insert、update d)select、delete、update

二、填空题(10X2=20分)

1.数据管理经历了、、三个阶段。2.

DB的中文含义是、DBMS的中文含义是、DBS的中文含义是、DBA的中文含义是。3.

数据库的三级体系结构为、、,两级映象为、,两级数据独立性为、。4.

SQL主要由、、三类语句组成。5.

数据库设计通常由规划、需求分析、、、、数据库实现、数据库运行与维护7个阶段构成。

三、应用题(3X5=15分)

设关系模式R,其中U={A,B,C,D},F={AB→C,C→A,C→D,D→B},试问:

1.关系R各属性的闭包。2.

关系R的所有候选码。

3.判断关系R是否属于3NF,并解释你的结论。

四、综合题(45分)

某学校要对学生成绩进行计算机管理。该学校有若干学生,每个学生有学号、班级、姓名、性别、出生日期、地址。开设的课程需要管理课程编号、课程名称、学分和学生选修该课程后的成绩等信息。该学校规定:一个学生可以有选修多门课程,一门课程可以有多名学生选修。

1.画出此管理系统的ER模型。

2.简述ER模型向关系模式转换的一般方法。3.

将以上ER模型转化为关系模式,包括主键、外键。4.

试用SQL语句表示以下数据编辑:

将新生“张三”插入学生表(其它属性自设)。②

删除选课表中学号为“0001”的学生的选课信息。③

将所有选修了课程编号为“c001”的学生成绩加5分。④

将所有选修了“数据库”课程的学生成绩提高5分。⑤

把低于总平均分的女同学的成绩提高5%。5.

试用代数表达式表示以下查询:

查询全校所有学生的学生表的所有信息。

查询全校所有地址为“西安”的学生的学号、姓名、性别。③

查询所有选修了“数据库”课程的学生的学号、姓名、成绩。④

查询选修了所有课程的学生的学号、姓名、性别。⑤

查询选修了2门课程以上的学生的学号、姓名、性别。⑥

查询学号为“0001”的学生没有选修的课程编号、课程名称。6.

试用SQL语句表示以下查询:

查询全校所有学生的学生表的所有信息。

查询全校所有地址为“西安”的学生的学号、姓名、性别。③

查询所有选修了“数据库”课程的学生的学号、姓名、成绩。④

查询每个学生所选课程的数量、总分、最高、最低分 ⑤

查询选修了所有课程的学生的学号、姓名、性别。⑥

查询选修了2门课程以上的学生的学号、姓名、性别。

数据库应用笔试样卷二参考答案

一、选择题(10X2=20分)

1.a)2.b)3.c)

4.d)5.d)6.c)7.b)8.a)9.a)10.b)

二、填空题(10X2=20分)

11.人工管理阶段、文件系统阶段、数据库阶段三个阶段。12.数据库、数据库管理系统、数据库系统、数据库管理员。

13.数据库的三级体系结构为外模式、概念模式、内模式,两级映象为外模式/模式映象、模式/内模式映象,两级数据独立性为物理数据独立性、逻辑数据独立性。14.SQL主要由 数据定义、数据操纵、数据控制三类语句组成。

15.数据库设计通常由规划、需求分析、概念设计、逻辑设计、物理设计、数据库实现、数据库运行与维护7个阶段构成。

三、应用题(3X5=15分)

16.A+=A,B+=B,C+=ABCD,D+=DB,(AB)+= ABCD 17.关系R的所有候选码。AB及C 18.关系R不属于3NF。

因为非候选码传递依赖于侯选键AB

四、综合题(45分)

某学校要对学生成绩进行计算机管理。该学校有若干学生,每个学生有学号、班级、姓名、性别、出生日期、地址。开设的课程需要管理课程编号、课程名称、学分和学生选修该课程后的成绩等信息。该学校规定:一个学生可以有选修多门课程,一门课程可以有多名学生选修。

1.ER模型。

2.ER模型向关系模式转换的一般方法。实体:

实体类型→关系模式。联系:

1∶1:将联系臵入任一端实体,并加入另一端实体主键为外键。1∶N:将联系臵入多端实体,并加入一端实体主键为外键。M∶N:建立新关系模式,主键为两端实体的主键,并为外键。3.关系模式

s(sno,class,sname,sex,birthday,addr)c(sno,cname,credit)sc(sno, cno,score)4.试用SQL语句表示以下数据编辑:

1.INSERT INTO S(sno, class, sname, sex)VALUE(‘0025’, ‘982’, ‘张三’, ‘男’)2.DELETE FROM SC WHERE SNO=‘0001’AND S.SNO=SCSNO 3.update sc set score=score+5 from where cno=’c001’ 4.update sc set score=score*(1+0.05)from c,sc where sname=’ 数据库’ and c.cno=sc.cno 5.update sc set score=score*(1+0.05)from s,sc where sex=’ 女’ and s.sno=sc.sno and score<(select avg(score)from sc)

5.试用代数表达式表示以下查询:

1.select * from s 2.select sno,sname,sex from s where address like '%西安% 3.select sc.sno,sname, score from s,c,sc where sc.sno=s.sno and sc.cno=c.cno and cname='数据库' 4.select sno,sname,sex from s where not exists(select * from c where not exists(select * from sc where sc.sno=s.sno and sc.cno=c.cno))5.select sc1.sno from sc as sc1,sc as sc2 where sc1.sno=sc2.sno and sc1.cno<>sc2.cno 6.select cno,cname from c where not exists(select cno from sc,s where s.sno=sc.sno and c.cno=sc.cno and sno='0001')。

6.试用SQL语句表示以下查询:

1.select * from s 2.select sno,sname,sex from s where address like '%西安% 3.select sc.sno,sname, score from s,c,sc where sc.sno=s.sno and sc.cno=c.cno and cname='数据库' 4.select sno,count(*)as num,sum(score), max(score), min(score)from sc group by sno 5.select sno,sname,sex from s where not exists(select * from c where not exists(select * from sc where sc.sno=s.sno and sc.cno=c.cno))6.select sc1.sno from sc as sc1,sc as sc2 where sc1.sno=sc2.sno and sc1.cno<>sc2.cno

笔试样卷三

参考答案

一、填空题(30分)

1.数据完整性包括、、。2.

SQL Server系统数据库包括、、、。3.

SQL Server中,数据库主数据文件扩展名为,次数据文件扩展名为,事务日志文件扩展名为。4.

SQL Server数据定义语句包括、、。

5.ER模型的中文名称为。6.

经典的结构数据模型包括、、。

7.专门的关系运算包括、、、。8.

SQL Server数据操纵命令包括、、、。

9.使用存储过程的目的是。10.

数据库索引包括、。

11.数据库系统3级结构包括、。

二、设有学生成绩库,包含三张表:

学生(学号,班级,姓名,性别,出生日期,地址,电话,信箱)课程(课程编号,课程名称,学分)选课(学号,课程编号,成绩)用SQL语句完成以下操作(50分)。

1、删除所有成绩为NULL的学生选课信息。

2、将所有不及格课程的成绩加5分。

3、将所有“数据库应用”课程的成绩加5分。

4、查询所有课程的所有信息。

5、查询所有学生的姓名、性别。

6、查询所有男生的姓名、年龄。

7、查询所有学生的平均成绩,并按平均成绩排名次。

8、查询所有选修了“数据库应用”课程的学生的学号、姓名和该课成绩。

9、查询张三同学没有选修的课程编号、课程名称。

10、查询所有学生都选修的课程编号、课程名称。

三、关系模式R(ABCD),F={AB→C,C→A,C→D,D→B}(20分)

1、关系R的所有候选码是什么?

2、R是否属于3NF,解释你的结论。

数据库应用笔试样卷三参考答案

一、填空题(30分)

1.数据完整性包括 实体完整性、参照完整性、用户定义完整性。2.SQL Server系统数据库包括 master、model、msdb、tempdb。

3.SQL Server中,数据库主数据文件扩展名为mdf,次数据文件扩展名为 ndf,事务日志文件扩展名为ldf。

4.SQL Server数据定义语句包括 create、drop、alter。5.ER模型的中文名称为实体联系模型。

6.经典的结构数据模型包括 层次、网状、结构。7.专门的关系运算包括 选择、投影、连接、除。

8.SQL Server数据操纵命令包括 insert、delete、update、select。9.使用存储过程的目的是 减轻网络流量、提高效率。10.数据库索引包括聚集、非聚集。

11.数据库系统3级结构包括外部级、概念级和内部级。

二、设有学生成绩库,包含三张表:

学生(学号,班级,姓名,性别,出生日期,地址,电话,信箱)课程(课程编号,课程名称,学分)选课(学号,课程编号,成绩)用SQL语句完成以下操作(50分)。

1.delete from sc where score is null 2.update sc set score=score+5 from where score<60 3.update sc set score=score+5 from c,sc where sname=’ 数据库’ and c.cno=sc.cno 4.select * from c 5.select sname.sex from s 6.select sname.year(getdate())-year(birthday)as age from s where sex=’ 男’ 7.select sno,avg(score)from sc group by sno order by 2 desc 8.select sc.sno,sname,cname,score from s,c,sc where sc.sno=s.sno and sc.cno=c.cno and cname='数据库' 9.select cno,cname from c where not exists(select cno from sc,s where c.cno=sc.cno and c.sno=s.sno and sname='张三')10.select cno,cname from c where not exists(select * from s where not exists(select * from sc where sc.sno=s.sno and sc.cno=c.cno))

三、关系模式R(ABCD),F={AB→C,C→A,C→D,D→B}(20分)

1.关系R的所有候选码。AB及C 2.关系R不属于3NF。因为非候选码传递依赖于侯选键AB

数据库试题及答案 两套 收藏 数据库原理试题(A卷)

一、填空题(每空 1 分,共 20 分)

1.对于一个国家来说,数据库的建设规模、数据库信息量的 _____________ 和 _____________ 已成为这个国家信息化程度的 ________________。2.数据模型通常由: ________________、________________ 和 _____________ 三部分组成。

3.游标的功能是把 ________________ 转换为 ________________。4.最常用的数据库的恢复技术是_____________ 和 _____________。

5._____________ 模型是现实世界到 _____________ 机器模型的中间桥梁。6.数据独立性是指_____________ 和_____________ 独立性。

7.数据库应用程序开发工具目前有 ________________、_________________、________________、和 ________________ 等。

8.目前数据库产品有 SQL Server 和 ________________、________________ 等。

二、选择题(每小题 1 分,共 10 分)

1.关于冗余数据的叙述中,不正确的是()。A .冗余的存在容易破坏数据库的完整性 B .冗余的存在给数据库的维护增加困难.C .不应该在数据库中存储任何冗余数据 D .冗余数据是指可由基本数据导出的数据 2.概念模型独立于()。

A . ER 模型 B .硬件设备 C . DBMS D .操作系统 3.下列叙述正确的为()。

A.主码是一个属性,它能唯一表识一列 B.主码是一个属性,它能唯一表识一行

C.主码是一个属性或属性集,它能唯一表识一列 D.主码是一个属性或属性集,它能唯一表识一行

4.数据库三级模式体系结构的划分,有利于保持数据库的()。

A .数据独立性 B .数据安全性 C .结构规范化 D .操作可行性 5.一个关系中的候选关键字()。

A .至多一个 B .可多个 C .必须多个 D .至少 3 个 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.恢复

三、判断题(每小题 1 分,共 10 分 , 对不正确的要写出理由)1.子模式 DDL 是用来描述数据库的物理存储结构的。()2.同一个关系模型的任两个元组值不能全同。()3.基本表是本身独立存在的表,在 SQL 中一个关系就对应基本表。()4.数据流程图(DFD)是用于描述结构化方法中详细设计阶段的工具。()5.若数据库中只包含成功事务提交的结果则此数据库成为处于安全状态()6.事务的持续性是指事务中包括的所有操作,要么都做,要么都不做。()7.DB 用户的权限可分为具有 DBA 特权的用户和一般 DB 用户()8.数据库的网状模型应满足的条件是必须有两个以上的结点。()

9.CREAT TABLE 命令可直接定义主码、外码、参照表,系统就能够自动地执行实体完整性和参照完整性规则。()

10.分布式数据库数据独立性包括数据的逻辑独立性、数据的物理独立性和数据分布独立性。()

四、(每小题 3 分,共 15 分)设有关系模式,其中

(1)计算。

(2)求 F 的最小等价依赖集。(3)求出 的关键字。

(4)将 R 分解使其满足 BCNF 且无损连接。

(5)将 R 分解使其满足 3NF 且无损连接与保持函数依赖。

五、综合题(25 分)

1.将 R ∪ S、R-S 两种关系代数基本运算表示为域关系演算表达式。(5 分)2.关系数据库中有下列三个关系:

商店(商店代号,商店名,店员人数,所在城市)商品(商品编号,商品名,价格)商店--商品(商店代号,商品编号,商品数量)(1)用 ALPHA 语言完成下列操作:(4 分)检索销售全部商品的商店姓名。

(2)用关系代数完成下列操作:(4 分)检索店员人数大于 23 商店代号和商店名。(3)试用 SQL 语句写出下列查询:

(a)找出店员人数不超过 100 人或者在长沙市的所有商店的代号和商店名。(4 分)(b)找出供应书包的商店名。(4 分)

(c)找出至少供应商品代号为 233 的商店所供应的全部商品的商店名。(4 分)

六、设计题(每小题 10 分,共 20 分)

某市人才交流中心拟建立人才信息交流网。现有资料:每个前来登记的个人需填写的《人才入库登记表》(见附表 1);每个前来登记的企业需填写的《企业信息登记表》(见附表 2)。

试设计人才、岗位和企业的实体联系图,并将概念模型转换为关系模式。附表 1 :人才入库登记表 个人编号: 登记日期 姓名

性别

出生日期 身份证号 毕业院校

专业

学历 联系电话

电子邮件

附表 2 :企业信息登记表 企业编号: 登记日期 企业名称

地址

企业网址 岗位需求 联系人

联系电话

电子邮件 企业简介

数据库原理试题答案(A卷)一.填空题(每空 1 分,共 20 分)

1.安全性,完整性,衡量标准

2.数据结构,数据操作,完整约束。3.集合记录,单记录

4.数据转储,登录日志文件 5.概念,数据模型 6.物理,逻辑

7.C++, VB, Def, C# 8.Oracle, Access

二、单项选择题(每小题 1 分,共 10 分)

C,C,D,A,B,C,B,D,A,B

三、判断题(每小题 1 分,共 10 分)

F,T,T,F,T,F,T,T,T

四、(每小题 3 分,共 15 分)

• 令 x={AD}, x(0)=AD, x(1)=ACD, x(2)=ACD, 故(AD)+ =ACD • 将 F 中依赖右部属性单一化: F 1 : A C C A B A B C D A D C 在 F 1 中去掉多余的函数依赖: 因为 B A,A C 所以 B C 是多余的 又因为 D A,A C 所以 D C 是多余的 F 2 : A C C A B A D A 函数依赖集的最小集不是唯一的,本题答案不唯一。

因为 F 2 中所有依赖的左部都是单属性,所以不存在依赖左部多余的属性。所以 F : A C C A B A D A(3)因为 DB 在 F 中的又函数依赖的右部中均未出现,所以候选关键字一定包含 BD,而(BD)+ =ABCD 因此 BD 是 R 惟一的候选关键字。(4)考虑 A C,所以 AC 不是 BCNF(AC 不包含候选关键字 BD),将 ABCD 分解为 AC 和 ABD。AC 已是 BCNF,进一步分解 ABC 选择 B A,把 ABD 分解为 AB 和 BD,此时 AB 和 AD 均为 BCNF,所以 ρ ={AC,BA,DA,BD}(5)Ri A B

C D AC BA DA a 1 a 1 a 1 a 2 a 3 a 3 a 3

a 4

五、,R US={t|P(t)US(t)`}

R-S={t|P(t)?S(t)`}(5 分),(1)SHOP(sno,sna,snu,city)

GOODS(gno,gna,price)

SHOP-GOODS(sno,gno,num)

Range GOODS rx

SHOP-GOODS ry

GET W(SHOP.SNA)rx ry(ry.gno=rx.gno shop.sno=ry.sno)

(2)∏ sno,sna(δ snu>23(SHOP))(3 分)

(3)(a)SELECT SNO,SNA

FROM SHOP

WHERE CITY=' 长沙 'OR SNO<=100(3 分)

分)((b)SELECT SHOP.sna

FROM SHOP,SHOP-GOODS,GOODS

WHERE SHOP.sno=SHOP-GOODS.sno AND GOODS.gna=' 书包 '

SHOP-GOODS.gno =GOODS.gno(4 分)

(c)SELECT sna

FROM SHOP sx

WHERE NOTEXIST

(SELECT *

FROM GOODS-SHOP sy

WHERE GOODS-SHOP.sno=' 223' AND NOTEXIST

(SELECT *

FROM SHOP-GOODS sz

WHERE sy.gno=sz.gno AND sx.sno=sz.sno))(5 分)

六、设计题

问题一: 设计人才、岗位和企业的实体联系图(5 分)

问题二: 转换关系模式(5 分)

(b)个人编号,岗位,最低薪水,登记日期

(c)企业编号,岗位,专业学历,薪水,备注,登记日期

(d)个人编号,姓名,性别,出生日期,身份证号,毕业院校,专业,学历,证书,名称,联系电话,电子邮件,个人简历,特长

(e)证书名称,证书编号

企业(企业编号,企业名称,联系人,联系电话,地址,企业网址,电子邮件,企业简介)

数据库原理试题(B卷)

一、填空题(每空 2 分,共 20 分)

1、关系中主码的取值必须唯一且非空,这是由 ___________ 完整性规则决定的。

2、当数据库被破坏后,如果事先保存了数据库副本和 ________________,就有可能恢复数据库。

3、数据库的 ____________ 是指数据库的正确性和相容性。

4、关系数据操作语言的特点是:操作对象与结果均为 ___________、操作的非过程性强、语言一体化、并且建立在数学理论基础之上。

5、SQL 是一种介于关系代数和 _____________ 之间的结构化的查询语言。

6、对于每一个外模式,数据库系统都有一个 _______________ 映象,它定义了该外模式与模式之间的对应关系。

7、视图是一个需表,它一经定义就可以和基本表一样被查询,但 _________ 操作将有一定的限制。

8、数据仓库是一个面向主题的、_____________、不可更新的、随时间不断变化的数据集合。

9、避免活锁的简单方法是采用 ________________ 的策略。

10、知识库系统和主动数据库系统是将数据库技术和 ______________ 技术相结合产生的。

二、选择题(每小题 1 分,共 10 分)

1、SQL 中,下列涉及空值的操作,不正确的是()

A . AGE IS NULL B . AGE IS NOT NULL C . AGE=NULL D . NOT(AGE IS NULL)

2、关系数据模型的三个组成部分中,不包括()

A .完整性规则 B .数据结构 C .数据操作 D .并发控制

3、DB, DBMS 和 DBS 三者间的关系是()

A . DB 包括 DBMS 和 DBS B . DBS 包括 DB 和 DBMS C . DBMS 包括 DBS 和 DB D . DBS 与 DB、DBMS 无关

4、数据库的并发操作可能带来的问题包括()

A .丢失更新 B .数据独立性会提高 C .非法用户的使用 D .增加数据的冗余度

5、并发事务的交叉执行破坏了事务的()

A .原子性 B .隔离性 C .一致性 D .永久性 6、3NF()规范化为 BCNF。

A .消除非主属性对码的部分函数依赖 B .消除非主属性对码的传递函数依赖 C .消除主属性对码的部分和传递函数依赖 D .消除非平凡且非函数依赖的多值依赖

7、()是长期存储在计算机内的有组织,可共享的数据集合。

A .数据库管理系统 B .数据库系统 C .数据库 D .文件组织

8、一个 1 : n 联系可以转换为一个独立的关系模式,关系的码为()

A .实体的码 B.各实体码的组合 C.n 端实体的码 D.每个实体的码

9、在数据库设计中,将 ER 图转换成关系数据模型的过程属于()

A.需求分析阶段 B.逻辑设计阶段 C.概念设计阶段 D.物理设计阶段

10、关系完备的系统是指()。

A.仅支持关系数据结构,不支持集合级的操作 B.仅支持关系数据结构和三种关系操作

C.支持关系数据结构和所有的关系代数操作 D.支持关系模型的所有特征

三、简答题(每小题 5 分,共 20 分)、数据库系统中的常见故障有那些?、简述数据模型的三个组成部分。、所有的视图是否都可以更新?为什么?、什么样的并发调度是正确的调度?

四、(共 10 分)事务 T1 和 T2 同时对 A 的值操作。A 的初值是 50,事务 T1 对 A 的值减 10,事务 T2 对 A 的值加倍,1、若这两个事务并发执行,举例可能结果。

2、请给出一个可串行化调度,并给出执行结果。

五、(共 10 分)对学生-课程数据库有如下的查询:

SELECT Sname

FROM Student, Cource , SC

WHERE Student.Sno=SC.Sno AND SC.Cno=Course.Course.Cno AND Course.Cname=' 数据库 '

此查询要求选修了数据库的所有学生的姓名。

(1)试画出用关系代数表示的语法树;

(2)对原始的语法树进行优化,画出优化后的标准语法树。

六、(共 20 分)设有学生-课程数据库,其数据库模式为 : 学生 S(学号 SNO,姓名 SN,所在系 SD,年龄 SA)、课程 C(课程号 CNO,课程姓名 CN,先修课号 PCNO)、学生选课 SC(学号 SNO,课程号 CNO,成绩 G)。、试用关系代数,ALPHA 语言语言分别写出下列查询:

(1)查询选修了 2 号课程的学生的学号;(4分)

(2)求选读了‘数据库概论'的学生学号和姓名;(4分)

(3)求选修了全部课程的学生学号、姓名。(4分)、试用 SQL 语言写出下列查询:

(1)查询学生总人数;(2分)

(2)查询选修了 5 门以上课程的学生学号;(3分)

(3)删除‘数据结构'课程及所有对它的选课情况。(3分)

七、综合题(共 10 分)

设有一局部应用,包括 3 个实体“科室”,“医生”,“病人”,且有以下事实:每位医生属于且仅属于一个科室;每个科室可以聘用若干医生,对每个医生聘用时存有聘用期限和聘用日期;一个病人可以由不同的医生为其诊断,每个医生可以为若干病人诊治,每次诊断存有就诊日期。设科室的属性包括科室代码,科室名称;医生的属性包括工号,姓名和职称;病人的属性包括姓名、年龄、工作单位。

1、试设计 E - R 图,注明属性和联系类型。

2、将 E - R 图转换为等价的关系模型(包括关系名,属性名和码)。

数据库原理试题答案(B卷)

一、填空题(每题 2 分,共 20 分)

1、实体

2、日志文件

3、完整性

4、关系

5、关系演算

6、外模式 / 模式

7、更新

8、集成的

9、先来先服务

10、人工智能

二、选择题(每题 1 分,共 10 分)、C 2、D 3、B 4、A 5、B 6、C 7、C 8、C 9、B 10、C

三、简答题(每题 5 分,共 20 分)、答案要点:数据库系统中的常见故障有:事务内部的故障(事务故障)(1 分)、系统故障(1 分)、介质故障(2 分)、计算机病毒(1 分)。、答案要点:数据模型通常由数据结构(1 分)、数据操作(2 分)、完整性约束(2 分)三部分组成。、答案要点:不是所有的视图都是可更新的(2 分);因为有些视图的更新不能唯一地有意义地转换成对相应基本表地更新(3 分)。、答案要点:多个事务的并发执行是正确的,当且仅当其结果与按某一次序串行执行它们时的结果相同(5 分)。

四、(共 10 分)、80,90、T 1 T 2

Slock A

读 A = 50

Y = A

Unlock A

Xlock A

A=Y-10 Slock A

写回 A = 40

等待

Unlock A 等待

读 A = 40

Y = A

Unlock A

Xlock A

A=Y × 2

写回 A = 80

Unlock A

五、(共 10 分)

六、(共 20 分)、关系代数:

(1)sno(cno =‘ 2 '(SC))(2分)

(2)Sno,Sn(Cn=' 数据库概论 ')(2分)

(3)Sno,SN(S(Cno,sno(SC)÷ Cno(C)))(2分)

ALPHA 语言

• GET W(SC.SNO): SC.CNO=' 2'(2分)

• RANGE C X

SC Y

GET W(S.SNO.S.SN): X(Y(X.CNO=Y.CNO ^ Y.SNO=S.SNO ^ X.CN=' 数据库概论 '

• RANGE C X

SC Y

GET W(S.SNO,S.SN): X(Y(Y.CNO=X.CNO ^ Y.SNO=S.SNO))(2分)、(1)SELECT COUNT(*)FROM STUDENT(2分)

(2)SELECT SNO FROM SC

GROUP BY SNO HAVING COUNT(*)>5(3分)

(3)DELECT FROM SC

WHERE SC.CNO IN(SELECT C.CNO FROM C WHERE CN=' 数据结构 ')

DELETE FROM C WHERE CN= ‘数据结构'(3分)

七、(共 10 分)

(5分)

科室(科室代码,科室名称)(1分)

医生(工号,姓名,名称,聘用日期,聘用期限,科室)(1分)

病人(病历号,姓名,年龄,工作单位)(1分)

2分)(就诊(医生工号,病历号,就诊日期)(2分)

发表于 @ 2008年12月29日 09:41:00 | 评论(4)| 编辑| 举报| 收藏

旧一篇:考试临近——在即 | 新一篇:学习IT的情感生活 查看最新精华文章 请访问博客首页相关文章

数据库概论笔记(第一天)数据库原理及应用《数据库系统概论》(第三版)数据库数据基础--基本概念数据库的基本结构三个层次数据库原理与应用数据库设计的理论与方法收藏数据库的主要特点hlf881216 发表于2009年12月9日 17:05:52 IP:举报回复删除 很好!!!riiiqpl 发表于2009年12月21日 21:51:03 IP:举报回复删除 看不到图片呀匿名用户 发表于2009年12月25日 13:02:42 IP:举报回复删除 zs84102030 发表于2009年12月28日 15:04:19 IP:举报回复删除 发表评论 表 情: 评论内容: 用 户 名: 登录 注册 匿名评论 匿名用户验 证 码: 重新获得验证码 Copyright © pengluer Powered by CSDN Blog

第三篇:数据库期末考试_试题及答案

数据库试题 4

一、填空题(共9题,每空1分,共15分)1.将数据库从SQL Server实例中删除,即在逻辑上将数据文件和日志文件与服务器相脱离,但文件并不从磁盘上删除,此操作称为_数据库分离,可通过(数据库附加)将其重新加载到SQL Server实例中。

2.SQL Server中用于服务器的所有初始化信息和系统级信息的的系统数据库是master。3.打开数据库student,使之成为当前数据库,可以使用语句_ use student _。

4.使用T-SQL语句创建存储过程时,若要求对存储过程的定义文本进行加密,应使用with encryption子句。

5.若要删除sutdent表的全部数据,数据删除后不可撤销,应使用语句truncate table student,,若想删除student数据表,应使用语句drop table student。

6.若要对数据库中的对象进行改名,就使用的系统存储过程是sp_rename。

7.Sql Server的数据库文件分为数据文件和日志文件,其中数据文件又分为主要数据文件、次要数据文件

8.在Sql Server中,按触发的时机,触发器可分为后触发器和替代触发器。9.在Sql Server的事务处理中,开启一个事务可用Begin Transaction,提交事 和撤销事务应使用Commit transaction,和rollback transaction。

二、简答题(共3题,每题7分,共21分)

1.在数据库端编程,主要有自定义函数、存储过程和触发器三种形式,请比较一下这三种方式的异同。

答:相同点:存储过程、触发器和自定义函数都能完成特定的功能,并且都存储在服务器端的数据字典中。区别:存储过程和自定义函数都可以定义参数,触发器不可以;从调用方式上,存储过程和自定义函数都需要由应用程序或其他功能体进行调用,而触发器是当相应事件发生时自动执行,不须干预;自定义函数需要定义返回类型,函数体中至少要有一条用于返回返回值的语句,而存储过程和触发器不需要。

2.SqlServer有哪些系统数据库,各自的作用是什么?

答:主要的系统数据库有master、model、tempdb和msdb。其中Master数据库保存了Sql Server2005的初始化信息和所有系统级信息。Master数据库是Sql Server 2005中最重要的系统数据库,对其更新和删除操作而导致Master数据库的不可用都将使得整个Sql Server2005系统无法启动和运行。Model数据库是用于保存所有用户数据库和Tempdb数据库的模版。每当用户创建数据库的时候,Sql Server 2005将用Model数据库提供的信息初始化被创建的数据库。Msdb数据库是Sql Server2005代理服务工作时使用的数据库,用于为Sql Server代理服务在警报和作业等操作时提供存储空间。Tempdb数据库是一个临时的系统数据库,用于为所有临时表、临时存储过程以及其他的临时操作提供存储空间。

3.数据库中的常用完整性有几种?在Sql Server主要通过什么方式实现?

答:视图是一个虚拟表,并不存储任何物理数据。视图与真正的表很类似,也是由一组命名的列和数据行组成,其内容由查询所定义。但是视图并不是以一组数据形式存储在数据库中,数据库中只存储视图的定义,而不存在视图中的数据,视图中的数据仍存储在基本表中。当基本表中的数据发生变化时,从视图中查询出来的数据也随之改变。视图和表相比有独特的优势主要有以下几个方面:(1)保证数据的安全。(2)简化查询操作。(3)保证数据的逻辑独立性。

三、应用题(共6题,本题共54分。)

1.创建名为“Love”的数据库,其中主数据文件为Lovedat.mdf,初始大小为8M,增长大小为1M,日志文件为Lovedat.ldf,初始大小是5M,最大存储空间是30M,增长是5M。请写出相应的SQL语句。(本题8分)Create database love on

log on(name=lovedat_log,filename='d:databaselovedat.ldf',size=5,Maxsize=30,filegrowth=5)

2.使用sql语句创建表authors,结构如下表所示(本题8分)列名 数据类型

N 大小

是否为空

姓名

默认值 说明

authorID int 4

编号(主键),自动增长

电话 地址(name=lovedat,filename='d:databaselovedat.mdf',size=8,Maxsize=unlimited,filegrowth=1)

authorName nvarchar 50 N Phone nvarchar 13 Y address nvarchar 255 Y

create table authors(authorid int identity(1,1)primary key not null, authorname nvarchar(50)not null,phone nvarchar(13)null, address nvarchar(255))

3.使用SQL语句对2中创建的authors表进行如下修改:(每小题5分,共15分)(1)添加Sex 列 char(2),city列 varchar(20)。

alter table authors add sex char(2)null,city nvarchar(20)null;(2)删除city列。

alter table authors drop column city(3)修改作者信息表authors中的address列将该列的属性的长度更改为500。alter table authors alter column address nvarchar(500)not null 4.系部表的创建语句如下,请完成以下操作(每小题5分,共15分)CREATE TABLE 系部

(系部代码 char(2)CONSTRAINT pk_xbdm PRIMARY KEY, 系部名称 varchar(30)NOT NULL,系主任 char(8))(1)将系部表中计算机系的系主任改为‘张中裕’

Update 系部 set 系主任=’ 张中裕’

where 系部名称=’计算机系’

(2)将系部表中的系部名称列中的‘系’全部更改为‘科学系’(使用replace函数,用法:replace(串1,串2,串3),其功能是将串1中的串2 替换为串3)Update 系部 set 系部名称=replace(系部名称,’系’,’科学系’)(3)在系部表中删除系主任姓‘张’的系部数据

Delete from 系部 where 系主任 like ‘张%’

5.有二个数据表XS(xh, xm)和XS_KC(xh, kch, cj),用两种方法,写出如下查询:“查找数据库中所有学生的学号(xh)、姓名(xm)以及其所选修的课程号(kch)和成绩(cj)”。(本题8分)

.(1)select xs.xh,xm,kch,cj from xs, xs_kc where xs.xh=xs_kc.xh;(2)select xs.xh,xm,kch,cj from xs join xs_kc on xs.xh=xs_kc.xh;

四、编程题(共2题,每题5分,共10分)

1.在数据表上机记录中创建一个名为insert_sjkh的insert触发器其作用是:当用户在“上机记录”表中插入记录时,若“上机卡”表中没有该上机号,则提示用户不能插入,否则,提示记录插入成功。(附:上机记录表结构:(上机号 char(13),上机日期 datetime,开始时间 datetime,结束时间 datetime,上机状态 bit)。上机卡表结构:(上机号 char(13),姓名„„)

Create trigger insert_sjkh on dbo.上机记录 for insert As begin Declare @asjkh char(13)Declare @acount int Select @asjkh=上机号from inserted Select @acount=count(*)from 上机卡where 上机号=@asjkh If @acount=0

Print '上机卡中无此卡号,不能插入' Else

Print '数据插入成功'

end

2.在student数据库中的学生、课程注册、课程表中创建一个带参的存储过程cjcx。其功能是:当任意输入一个学生的姓名时,返回该学生的学号、选修的课程名和课程成绩。然后使用存储过程,查询学生“陈斌”的学号、选修的课程名和课程成绩。Create PROCEDURE [dbo].[cjcx]

AS BEGIN SELECT 学生.学号,课程.课程名,课程注册.成绩 from

学生,课程,课程注册

where 学生.学号=课程注册.学号 and 课程注册.课程号=课程.课程号 and 姓名=@axm END 执行存储过程cjcx,查询“周红瑜”的学号、选修的课程名和课程成绩。Exec cjcx @axm=’张斌’ @axm char(8)

第四篇:数据库sql课后练习题及答案解析

先创建下面三个表:

(book表)

(borrow表)

(reader表)

1)找出姓李的读者姓名(NAME)和所在单位(COMPANY)。

2)列出图书库中所有藏书的书名(BOOK_NAME)及出版单位(OUTPUT)。3)查找“高等教育出版社”的所有图书名称(BOOK_NAME)及单价(PRICE),结果按单价降序排序。

4)查找价格介于10元和20元之间的图书种类(SORT),结果按出版单位(OUTPUT)和单价(PRICE)升序排序。

5)查找书名以”计算机”开头的所有图书和作者(WRITER)。

6)检索同时借阅了总编号(BOOK_ID)为112266和449901两本书的借书证号(READER_ID)。

##7)* 查找所有借了书的读者的姓名(NAME)及所在单位(COMPANY)。8)* 找出李某所借所有图书的书名及借书日期(BORROW_DATE)。

9)* 无重复地查询2006年10月以后借书的读者借书证号(READER_ID)、姓名和单位。

##10)* 找出借阅了一书的借书证号。

11)找出与”赵正义”在同一天借书的读者姓名、所在单位及借书日期。12)查询2006年7月以后没有借书的读者借书证号、姓名及单位。#13)求”科学出版社”图书的最高单价、最低单价、平均单价。##14)* 求”信息系”当前借阅图书的读者人次数。

#15)求出各个出版社图书的最高价格、最低价格和总册数。#16)分别找出各单位当前借阅图书的读者人数及所在单位。

17)* 找出当前至少借阅了2本图书(大于等于2本)的读者姓名及其所在单位。18)分别找出借书人次数多于1人次的单位及人次数。

19)找出藏书中各个出版单位的名称、每个出版社的书籍的总册数(每种可能有多册)、书的价值总额。

20)查询经济系是否还清所有图书。如果已经还清,显示该系所有读者的姓名、所在单位和职称。

附录:建表语句

创建图书管理库的图书、读者和借阅三个基本表的表结构: 创建BOOK:(图书表)

CREATE TABLE BOOK(BOOK_ID int, SORT VARCHAR(10), BOOK_NAME VARCHAR(50), WRITER VARCHAR(10), OUTPUT VARCHAR(50), PRICE int);

创建READER:(读者表)

CREATE TABLE READER(READER_ID int, COMPANY VARCHAR(10), NAME VARCHAR(10), SEX VARCHAR(2), GRADE VARCHAR(10), ADDR VARCHAR(50));

创建BORROW:(借阅表)

CREATE TABLE BORROW(READER_ID int, BOOK_ID int, BORROW_DATE datetime)

插入数据: BOOK表: insert into BOOK values(445501,'TP3/12','数据库导论','王强','科学出版社',17.90);insert into BOOK values(445502,'TP3/12','数据库导论','王强','科学出版社',17.90);insert into BOOK values(445503,'TP3/12','数据库导论','王强','科学出版社',17.90);insert into BOOK values(332211,'TP5/10','计算机基础','李伟','高等教育出版社',18.00);insert into BOOK values(112266,'TP3/12','FoxBASE','张三','电子工业出版社',23.60);insert into BOOK values(665544,'TS7/21','高等数学','刘明','高等教育出版社',20.00);insert into BOOK values(114455,'TR9/12','线性代数','孙业','北京大学出版社',20.80);insert into BOOK values(113388,'TR7/90','大学英语','胡玲','清华大学出版社',12.50);insert into BOOK values(446601,'TP4/13','数据库基础','马凌云','人民邮电出版社',22.50);insert into BOOK values(446602,'TP4/13','数据库基础','马凌云','人民邮电出版社',22.50);insert into BOOK values(446603,'TP4/13','数据库基础','马凌云','人民邮电出版社',22.50);insert into BOOK values(449901,'TP4/14','FoxPro大全','周虹','科学出版社',32.70);insert into BOOK values(449902,'TP4/14','FoxPro大全','周虹','科学出版社',32.70);insert into BOOK values(118801,'TP4/15','计算机网络','黄力钧','高等教育出版社',21.80);insert into BOOK values(118802,'TP4/15','计算机网络','黄力钧','高等教育出版社',21.80);

READER表: insert into reader values(111,'信息系','王维利','女','教授','1号楼424');insert into reader values(112,'财会系','李 立','男','副教授','2号楼316');insert into reader values(113,'经济系','张 三','男','讲师','3号楼105');insert into reader values(114,'信息系','周华发','男','讲师','1号楼316');insert into reader values(115,'信息系','赵正义','男','工程师','1号楼224');insert into reader values(116,'信息系','李 明','男','副教授','1号楼318');insert into reader values(117,'计算机系','李小峰','男','助教','1号楼214');insert into reader values(118,'计算机系','许鹏飞','男','助工','1号楼216');insert into reader values(119,'计算机系','刘大龙','男','教授','1号楼318');insert into reader values(120,'国际贸易','李 雪','男','副教授','4号楼506');insert into reader values(121,'国际贸易','李 爽','女','讲师','4号楼510');insert into reader values(122,'国际贸易','王 纯','女','讲师','4号楼512');insert into reader values(123,'财会系','沈小霞','女','助教','2号楼202');insert into reader values(124,'财会系','朱 海','男','讲师','2号楼210');insert into reader values(125,'财会系','马英明','男','副教授','2号楼212');

BORROW表: insert into borrow values(112,445501,'3-19-2006');insert into borrow values(125,332211,'2-12-2006');insert into borrow values(111,445503,'8-21-2006');insert into borrow values(112,112266,'3-14-2006');insert into borrow values(114,665544,'10-21-2006');insert into borrow values(120,114455,'11-2-2006');insert into borrow values(120,118801,'10-18-2006');insert into borrow values(119,446603,'11-12-2006');insert into borrow values(112,449901,'10-23-2006');insert into borrow values(115,449902,'8-21-2006');insert into borrow values(118,118801,'9-10-2006');

现有关系数据库如下:

数据库名:图书借阅管理系统

读者表(读者编号 char(6),姓名,性别,年龄,单位,身份证号,职称)图书表(图书编号char(6),图书名称,出版社,作者)借阅表(读者编号,图书编号,借阅时间)用SQL语言实现下列功能的sql语句代码。(1)创建数据表book;

book表(图书编号 char(6),图书名称,出版社,作者)要求使用:主键(图书编号)、非空(图书名称),非空(作者)(2)创建数据表reader表;

学生信息表(reader编号 char(8),姓名,性别,年龄,工作单位,身份证号,职称)要求使用:主键(reader编号)、默认(职称)、非空(工作单位,姓名)、唯一(身份证号)、检查(性别),检查(年龄)(3)创建借书表borrow;

borrow(ID,读者编号,图书编号,借书日期)要求使用:外键(学号,课号)(4)将下列课程信息添加到book表的代码

图书编号 名称

100101 数据库原理 100102 数据结构

修改 课号为100102的图书名称:数据结构与算法 删除 课号为100101的图书信息(5)创建视图读者借书信息的代码;

读者借书信息视图(读者编号,姓名,图书编号,图书名称,借书日期)(6)从读者表book中查询姓李的女读者的情况:姓名、性别、工作单位。(7)查询统计出借书量超过5本的单位平均年龄

(8)创建带参数的存储过程[借某图书的读者高低均年龄]、执行该过程的代码

存储过程功能:查询借阅某图书的的读者最高年龄、最低年龄、平均年龄;

执行该过程,查询所有借阅’数据库基础’这本书的读者的最高年龄、最低年龄、平均年龄;

1)找出姓李的读者姓名(NAME)和所在单位(COMPANY)。

SELECT NAME,COMPANY FROM READER WHERE NAME LIKE '李%'

2)列出图书库中所有藏书的书名(BOOK_NAME)及出版单位(OUTPUT)。

SELECT BOOK_NAME, OUTPUT FROM BOOK

3)查找“高等教育出版社”的所有图书名称(BOOK_NAME)及单价(PRICE),结果按单价降序排序。

SELECT BOOK_NAME,PRICE FROM BOOK WHERE OUTPUT='高等教育出版社' ORDER BY PRICE DESC 4)查找价格介于10元和20元之间的图书种类(SORT),结果按出版单位(OUTPUT)和单价(PRICE)升序排序。

SELECT SORT,OUTPUT,PRICE FROM BOOK WHERE PRICE BETWEEN 10 AND 20 ORDER BY OUTPUT ,PRICE

5)查找书名以”计算机”开头的所有图书和作者(WRITER)。

SELECT BOOK_NAME,WRITER FROM BOOK WHERE BOOK_NAME LIKE '计算机%' 6)检索同时借阅了总编号(BOOK_ID)为112266和449901两本书的借书证号(READER_ID)。

SELECT A.READER_ID FROM BORROW A,BORROW B WHERE A.BOOK_ID='112266' AND B.BOOK_ID='449901' AND A.READER_ID=B.READER_ID

##7)* 查找所有借了书的读者的姓名(NAME)及所在单位(COMPANY)。

SELECT DISTINCT NAME,COMPANY FROM READER,BORROW WHERE BORROW.READER_ID=READER.READER_ID

8)* 找出李某所借所有图书的书名及借书日期(BORROW_DATE)。

SELECT BOOK.BOOK_NAME,BORROW.BORROW_DATE FROM BOOK,BORROW,READER WHERE BOOK.BOOK_ID=BORROW.BOOK_ID AND

READER.READER_ID=BORROW.READER_ID AND READER.NAME LIKE '李%'

9)* 无重复地查询2006年10月以后借书的读者借书证号(READER_ID)、姓名和单位。

SELECT READER_ID,NAME,COMPANY FROM READER WHERE READER_ID IN(SELECT READER_ID FROM BORROW WHERE BORROW_DATE >='2006-10-1')

##10)* 找出借阅了一书的借书证号。

SELECT DISTINCT READER_ID FROM BORROW,BOOK WHERE BORROW.BOOK_ID=BOOK.BOOK_ID AND BOOK.BOOK_NAME LIKE 'FoxPro大全'

11)找出与”赵正义”在同一天借书的读者姓名、所在单位及借书日期。

SELECT NAME,COMPANY,BORROW_DATE FROM READER,BORROW WHERE BORROW.READER_ID=READER.READER_ID AND BORROW_DATE IN(SELECT BORROW_DATE FROM BORROW,READER WHERE BORROW.READER_ID=READER.READER_ID AND NAME='赵正义')

12)查询2006年7月以后没有借书的读者借书证号、姓名及单位。

SELECT READER_ID,NAME,COMPANY FROM READER WHERE READER_ID NOT IN(SELECT READER_ID FROM BORROW WHERE BORROW_DATE>='2006-7-1')

#13)求”科学出版社”图书的最高单价、最低单价、平均单价。

SELECT MAX(PRICE)最高单价,MIN(PRICE)最低单价,AVG(PRICE)平均单价 FROM BOOK WHERE OUTPUT='科学出版社'

##14)* 求”信息系”当前借阅图书的读者人次数。

SELECT COUNT(DISTINCT READER_ID)当前借阅图书的读者人次数FROM BORROW WHERE READER_ID IN(SELECT READER_ID FROM READER WHERE COMPANY IN('信息系'))

#15)求出各个出版社图书的最高价格、最低价格和总册数。

SELECT MAX(PRICE)最高价格,MIN(PRICE)最低价格,COUNT(PRICE)总册数FROM BOOK GROUP BY OUTPUT

#16)分别找出各单位当前借阅图书的读者人数及所在单位。

SELECT COUNT(COMPANY)读者人数,COMPANY FROM BORROW,READER WHERE BORROW.READER_ID=READER.READER_ID GROUP BY COMPANY

17)* 找出当前至少借阅了2本图书(大于等于2本)的读者姓名及其所在单位。

SELECT NAME 读者姓名,COMPANY 单位FROM READER WHERE READER_ID IN(SELECT READER_ID FROM BORROW GROUP BY READER_ID HAVING COUNT(*)>=2)

18)分别找出借书人次数多于1人次的单位及人次数。

SELECT COMPANY,COUNT(*)人次数 FROM READER,BORROW WHERE BORROW.READER_ID=READER.READER_ID GROUP BY COMPANY HAVING COUNT(*)>1

19)找出藏书中各个出版单位的名称、每个出版社的书籍的总册数(每种可能有多册)、书的价值总额。

SELECT OUTPUT,COUNT(*)书籍的总册数,SUM(PRICE)书的价值总额 FROM BOOK GROUP BY OUTPUT

20)查询经济系是否还清所有图书。如果已经还清,显示该系所有读者的姓名、所在单位和职称。

SELECT NAME,COMPANY FROM READER WHERE NOT EXISTS(SELECT* FROM READER,BORROW WHERE READER.READER_ID=BORROW.READER_ID AND COMPANY='经济系')

第五篇:数据库设计课后答案

第六章

数据库设计

习题解答和解析

1.1.试述数据库设计过程。

答:这里只概要列出数据库设计过程的六个阶段:

(1)需求分析;(2)概念结构设计;(3)逻辑结构设计;(4)数据库物理设计;(5)数据库实施;(6)数据库运 行和维护。这是一个完整的实际数据库及其应用系统的设计过程。不仅包括设计数据库本身,还包括数据库的实施、运行和维护。设计一个完善的数据库应用系统往往是上述六个阶段的不断反复。

解析:希望读者能够认真阅读《概论》6.1的内容,了解并掌握数据库设计过程。2.2.试述数据库设计过程各个阶段上的设计描述。答:各阶段的设计要点如下:

(1)需求分析:准确了解与分析用户需求(包括数据与处理)。

(2)概念结构设计:通过对用户需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型。

(3)逻辑结构设计:将概念结构转换为某个DBMS所支持的数据模型,并对其进行优化。(4)数据库物理设计:为逻辑数据模型选取一个最适合应用环境的物理结构(包括存储结构和存取方法)。

(5)数据库实施:设计人员运用DBMS提供的数据语言、工具及宿主语言,根据逻辑设计和物理设计的结果建立数据库,编制与调试应用程序,组织数据入库,并进行试运行。

(6)数据库运行和维护:在数据库系统运行过程中对其进行评价、调整与修改。解析:

这是进一步了解数据库设计的具体内容。设计描述是指在各个阶段体现设 计内容,描述设计结果的各种文档、程序。读者可以参考《概论》上图6.3。

3.3.试述数据库设计过程中结构设计部分形成的数据库模式。答:数据库结构设计的不同阶段形成数据库的各级模式,即:

(1)在概念设计阶段形成独立于机器特点,独立于各个DBMS产品的概念模式,在本篇中就是E-R图;

(2)在逻辑设计阶段将E-R图转换成具体的数据库产品支持的数据模型,如关系模型,形成数据库逻辑模式,然后在基本表的基础上再建立必要的视图(View),形成数据的外模式;

(3)在物理设计阶段,根据DBMS特点和处理的需要,进行物理存储安排,建立索引,形成数据库内模式。

读者可以参考《概论》上图6.4。图中概念模式是面向用户和设计人员的,属于概念模型的层次;逻辑模式、外模式、内模式是DBMS支持的模式,属于数据模型的层次,可以在DBMS中加以描述和存储。

4.4.试述数据库设计的特点。

答:数据库设计既是一项涉及多学科的综合性技术又是一项庞大的工程项目。其主要特点有:

(1)数据库建设是硬件、软件和干件(技术与管理的界面)的结合。

(2)从软件设计的技术角度看,数据库设计应该和应用系统设计相结合,也就是说,整个设计过程中要把结构(数据)设计和行为(处理)设计密切结合起来。详细的可以参考《概论》上6.1.2。

5.5.需求分析阶段的设计目标是什么?调查的内容是什么? 答:需求分析阶段的设计目标是通过详细调查现实世界要处理的对象(组织、部 门、企业等),充分了

解原系统(手工系统或计算机系统)工作概况,明确用户的各种需求,然后在此基础上确定新系统的功能。

调查的内容是“数据”和“处理”,即获得用户对数据库的如下要求:

(1)信息要求,指用户需要从数据库中获得信息的内容与性质,由信息要求可以导出数据要求,即在数据库中需要存储哪些数据;

(2)处理要求,指用户要完成什么处理功能,对处理的响应时间有什么要求,处理方式是批处理还是联机处理;

(3)安全性与完整性要求。

详细的可以参考《概论》上6.2。

6.6.数据字典的内容和作用是什么? 答:数据字典是系统中各类数据描述的集合。数据字典的内容通常包括:(1)数据项;(2)数据结构;(3)数据流;(4)数据存储;(5)处理过程五个部分。

其中数据项是数据的最小组成单位,若干个数据项可以组成一个数据结构。数据字典通过对数据项和数据结构的定义来描述数据流和数据存储的逻辑内容。

数据字典的作用:数据字典是关于数据库中数据的描述,在需求分析阶段建立,是下一步进行概念设计的基础,并在数据库设计过程中不断修改、充实、完善。(详细参考《概论》上6.2.3。注意,数据库设计阶段形成的数据字典与第十一章DBMS中的数据字典不同,后者是DBMS关于数据库中数据的描述,当然两者是有联系的)。

7.7.什么是数据库的概念结构?试述其特点和设计策略。答:概念结构是信息世界的结构,即概念模型,其主要特点是:

(1)能真实、充分地反映现实世界,包括事物和事物之间的联系,能满足用户对数据的处理要求,是对现实世界的一个真实模型;

(2)易于理解,从而可以用它和不熟悉计算机的用户交换意见,用户的积极参与是数据库设计成功的关键;

(3)易于更改,当应用环境和应用要求改变时,容易对概念模型修改和扩充;(4)易于向关系、网状、层次等各种数据模型转换。概念结构的设计策略通常有四种:

l)自顶向下,即首先定义全局概念结构的框架,然后逐步细化;

2)自底向上,即首先定义各局部应用的概念结构,然后将它们集成起来,得到全局概念结构;

3)逐步扩张,首先定义最重要的核心概念结构,然后向外扩充,以滚雪球的方式逐步生成其他概念结构,直至总体概念结构;

4)混合策略,即将自顶向下和自底向上相结合,用自顶向下策略设计一个全局概念结构的框架,以它为骨架集成由自底向上策略中设计的各局部概念结构。详细参考《概论》上6.3。

8.8.什么叫数据抽象?试举例说明。

答:数据抽象是对实际的人、物、事和概念进行人为处理,抽取所关心的共同特性,忽略非本质的细节, 并把这些特性用各种概念精确地加以描述,这些概念组成了某种模型。如“分类”这种抽象是:定义某一类概念作为现实世界中一组对象的类型。这些对象具有某些共同的特性和行为。它抽象了对象值和型之间的“is member of” 的语义。在E-R模型中,实体型就是这种抽象。例如在学校环境中,李英是老师,表示李英是教师类型中的一员,则教师是实体型,李英是教师实体型中的一个实体值,具有教师共同的特性和行为:在某个系某个专业教学,讲授某些课程,从事某个方向的科研。

9.9.试述数据库概念结构设计的重要性和设计步骤。

答:重要性:数据库概念设计是整个数据库设计的关键,将在需求分析阶段所得到的应用需求首先抽

象为概念结构,以此作为各种数据模型的共同基础,从而能更好地、更准确地用某一DBMS实现这些需求。

设计步骤:概念结构的设计方法有多种,其中最经常采用的策略是自底向上方法,该方法的设计步骤通常分为两步:第1步是抽象数据并设计局部视图,第2步是集成局部视图,得到全局的概念结构(如《概论》图6.9 所示)。

10.什么是E-R图?构成E-R图的基本要素是什么? 答:E-R图为实体-联系图,提供了表示实体型、属性和联系的方法,用来描述现实世界的概念模型。

构成E-R图的基本要素是实体型、属性和联系,其表示方法为:(1)实体型,用矩形表示,矩形框内写明实体名;

(2)属性,用椭圆形表示,并用无向边将其与相应的实体连接起来;

(3)联系,用菱形表示,菱形框内写明联系名,并用无向边分别与有关实体连接起来,同时在无向边旁标上联系的类型(1:1,1:n或m:n)。

解析:E-R图的概念是在第一章中讲解的,读者可以复习《概论》1.2.2 概念模型的 内容。

11.为什么要视图集成?视图集成的方法是什么? 答:在对数据库系统进行概念结构设计时一般采用自底向上的设计方法,把繁杂的大系统分解子系 统。首先设计各个子系统的局部视图,然后通过视图集成的方式将各子系统有机地融合起来,综合成一个系统的总视图。这样,设计清晰,由简到繁。由于数据库系统是从整体角度看待和描述数据的,因此数据不再面向某个应用而是整个系统。因此必须进行视图集成,使得数据库能被全系统的多个用户、多个应用共享使用。

一般说来,视图集成可以有两种方式:

(1)多个分E-R图一次集成,如《概论》图6.25(a)所示;(2)逐步集成,用累加的方式一次集成两个分E-R图,如《概论》图6.25(b)所示。无论采用哪种方式,每次集成局部E-R图时都需要分两步走:

  合并,解决各分E-R图之间的冲突,将各分E-R图合并起来生成初步E-R图;   修改和重构,消除不必要的冗余,生成基本E-R图。12.什么是数据库的逻辑结构设计?试述其设计步骤。

答:数据库的逻辑结构设计就是把概念结构设计阶段设计好的基本E-R图转换为与选用的DBMS产品所

支持的数据模型相符合的逻辑结构。设计步骤为(《概论》图6.31):

(1)将概念结构转换为一般的关系、网状、层次模型;

(2)将转换来的关系、网状、层次模型向特定DBMS支持下的数据模型转换;(3)对数据模型进行优化。

13.试述把E-R图转换为DBTG模型和关系模型的转换规则。答:E-R图向DBTG模型的转换规则:

(1)每个实体型转换为记录型,实体的属性转换为记录的数据项;(2)实体型之间1:n(n1)的联系转换为一个系,没有任何联系的实体型转换为奇异系;

(3)K(K2)个实体型之间多对多的联系,引入一个连结记录,形成K个实体型和连结记录之间的K个系。连结记录的属性由诸首记录的码及联系属性所组成;

(4)同一实体型内的1:n,n:m联系,引入连结记录,转换为两个系。

解析:根据我国实际情况,网状,层次数据库系统已很少使用,因此《概论》第三版 把它们删去了,有关的主要概念放在第一章数据模型中介绍。对于DBTG模型的许多概念也介绍得很简单。本题的内容已经超出了书上的内容,读者只要了解就可以了。但是,下面E-R图向关系模型的转换规则要求同学必须掌握,并且能够举一反三。

答:E-R图向关系模型的转换规则:一个实体型转换为一个关系模式。实体的属性就是关系的属性,实体的码就是关系的码。

对于实体间的联系则有以下不同的情况:

(1)一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,每个实体的码均是该关系的候选码。如果与某一端实体对应的关系模式合并,则需要在该关系模式的属性中加入另一个关系模式的码和联系本身的属性。(2)一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并。如果转换为一个独立的关系摸式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为n端实体的码。

(3)一个m:n 联系转换为一个关系模式。与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,各实体码的组合组成该关系的码,或码的一部分。

(4)3个或3个以上实体间的一个多元联系可以转换为一个关系模式。与该多元联系相连的各实体的码以及联系本身的属性均转换为关系的属性,而关系的码为各实体码的组合。

(5)具有相同码的关系模式可以合并。

14.你能给出由E-R图转换为IMS模型的转换规则吗? 答:E-R图向IMS模型的转换规则:

(1)每个实体型转换为记录型,实体的属性转换为记录的数据项;(2)实体型之间1:n(n1)的联系转换记录型之间的有向边;

(3)实体型之间m:n(m>1,n>1)的联系则分解成一对多联系,再根据(2)转换;(4)K(K2)个实体型之间多对多的联系,可先转换成多对两个实体型之间的联系,再根据(3)转换。

解析:IMS是IBM公司的层次数据库管理系统。IMS 模型是层次模型。E-R图向IMS模型转换的另一种方法是,先把E-R图转换为网状模型,再利用IMS逻辑数据库LDB的概念来表示网状模型。详细方法这里从略。

15.试把第一章习题12和习题13中的E-R图转换为DBTG模型、IMS模型、关系模型。答:下面是第一章习题 12 的 E-R 图 : 各实体的属性为:(简便起见,未用图表示)系:系编号,系名

班级:班级编号,班级名 教研室:教研室编号,教研室 学生:学号,姓名,学历 课程:课程编号,课程名 教员:职工号,姓名,职称 各联系的属性为: 选修课:成绩 其他联系无属性。

该E-R图的DBTG模型如下页所示 其关系模型为:

系(系编号,系名,学校名)班级(班级编号,班级名,系编号)教研室(教研室编号,教研室,系编号)学生(学号,姓名,学历,班级编号,导师职工号)课程(课程编号,课程名)教员(职工号,姓名,职称,教研室编号)选课(学号,课程编号,成绩)习题13的E-R图: 各实体的属性为:(方便起见,未用图表示)产品:产品号,产品名 零件:零件号,零件名

原材料:原材料号,原材料名,类别 仓库:合库号,仓库名 各联系的属性为: 产品组成:使用零件量 零件制造:使用原材料量 零件存储:存储量 材料存放:存放量

其DBTG模型如下页图所示。对应的IMS模型从略。

对应的关系模型为(其中有下横线的属性是主码属性): 产品(产品号,产品名,仓库号)零件(零件号,零件名)原材料(原材料号,原材料名,类别,仓库号,存放量)仓库(仓库号,仓库名)产品组成(产品号,零件号,使用零件量)零件组成(零件号,原材料号,使用原材料量)零件储存(零件号,仓库号,存储量)16.试述逻辑设计阶段中运用LRA方法优化模型的方法和步骤。答:(从略,此题不作要求)17.试用规范化理论中有关范式的概念分析习题15中你设计的关系模型中各个关系模式的码,它们属于第几范式?会产生什么更新异常? 答:习题15中设计的两个关系数据库的各个关系模式的码都用下划线注明,这些关系模式都只有一个码,且都是惟一决定的因素,所以都属于BCNF。不会产生更新异常现象。

18.规范化理论对数据库设计有什么指导意义? 答:规范化理论为数据库设计人员判断关系模式的优劣提供了理论标准,可用以指导关系数据模型的优化,用来预测模式可能出现的问题,为设计人员提供了自动产生各种模式的算法工具,使数据库设计工作有了严格的理论基础(可参考《概论》上数据模型的优化)。

19.试述数据库物理设计的内容和步骤。答:数据库在物理设备上的存储结构与存取方法称为数据库的物理结构,它依赖于给定的DBMS。为一个给定的逻辑数据模型选取一个最适合应用要求的物理结构,就是数据库的物理设计的主要内容。

数据库的物理设计步骤通常分为两步:

(1)确定数据库的物理结构,在关系数据库中主要指存取方法和存储结构;

(2)对物理结构进行评价,评价的重点是时间效率和空间效率。详细参考《概论》上6.5.10。

20.你能给出关系数据库物理设计的主要内容吗?例如Oracle数据库物理设计的内容。答:关系数据库物理设计的内容主要包括:(1)为关系模式选择存取方法;(2)设计关系、索引等数据库文件的物理存储结构。详细参考《概论》上6.5.2和6.5.3。

有关Oracle数据库物理设计的内容请参考其技术资料,根据上述内容进行总结。21.数据输入在实施阶段的重要性是什么?如何保证输入数据的正确性? 答:数据库是用来对数据进行存储、管理与应用的,因此在实施阶段必须将原有 系统中的历史数据输入到数据库。数据量一般都很大,而且数据来源于部门中的各个不同的单位。数据的组织方式、结构和格式都与新设计的数据库系统有相当的差距,组织数据录人就要将各类源数据从各个局部应用中抽取出来,分类转换,最后综合成符合新设计的数据库结构的形式,输入数据库。因此这样的数据转换、组织入库的工作是相当费力费时的工作。特别是原系统是手工数据处理系统时,各类数据分散在各种不同的原始表格、凭证、单据之中,数据输入工作量更大。

保证输入数据正确性的方法:为提高数据输入工作的效率和质量,应该针对具体的应用环境设计一个数据录入子系统,由计算机来完成数据入库的任务。

在源数据入库之前要采用多种方法对它们进行检验,以防止不正确的数据入库。详细参考《概论》上6.6.1。

22.什么是数据库的再组织和重构造?为什么要进行数据库的再组织和重构造? 答:数据库的再组织是指:按原设计要求重新安排存储位置、回收垃圾、减少指针链等,以提高系统性能。数据库的重构造则是指部分修改数据库的模式和内模式,即修改原设计的逻辑和物理结构。数据库的再组织是不修改数据库的模式和内模式的。进行数据库的再组织和重构造的原因:数据库运行一段时间后,由于记录不断增、删、改,会使数据库的物理存储情况变坏,降低了数据的存取效率,数据库性能下降,这时DBA就要对数据库进行重组织。DBMS一般都提供用于数据重组织的实用程序。数据库应用环境常常发生变化,如增加新的应用或新的实体,取消了某些应用,有的实体与实体间的联系也发生了变化等,使原有的数据库设计不能满足新 的需求,需要调整数据库的模式和内模式。这就要进行数据库重构造。

23.现有一局部应用,包括两个实体:“出版社”和“作者”,这两个实体是多对多的联系,请读者自己设计适当的属性,画出E-R图,再将其转换为关系模型(包括关系名、属性名、码和完整性约束条件)。

答:E-R图为: 关系模型为:

作者(作者号,姓名,年龄,性别,电话,地址)出版社(出版社号,名称,地址,联系电话)出版(作者号,出版社号,书的数量)出版关系的主码作者号,出版社号分别参照作者关系的主码作者号和出版 社关系的主码出版社号。

24.请设计一个图书馆数据库,此数据库中对每个借阅者保存读者记录,包括:读者号,姓名,地址,性别,年龄,单位。对每本书存有:书号,书名,作者,出版 社。对每本被借出的书存有读者号、借出日期和应还日期。要求:给出E-R图,再将其转换为关系模型。

答:E-R图为:

关系模型为:

读者(读者号,姓名,地址,性别,年龄,单位)书(书号,书名,作者,出版社)借书(读者号,书号,借出日期,应还日期)

大作业

完成一个实际部门的数据库应用系统设计全过程。

包括:需求调查、数据库设计、数据库建立、数据输入、应用系统设计和开发、用户界面的设计和实现等。

要求:

1.人员:5-6人。2.分工:每个人担任不同的角色,包括系统分析人员、系统设计人员、数据库设计人员、应用系统开发人员、测试人员等。分工协作,共同完成设计和开发任务,从而培养团队精神。

3.选择一个合适的DBMS产品或者使用学校提供的DBMS产品,选择合适的应用开发工具,按照设计的结果建立数据库、开发应用系统、输入数据、调试运行你们的系统。

4.要求写出完整的实验报告,包括:需求调查报告、系统分析报告、数据库设计报告、应用系统设计报告、数据库实施计划、系统测试计划、系统测试报告、用户使用手册等文档。

5.向老师和其他小组运行演示开发的数据库应用系统,提交所有文档。

6.集体讨论、互相学习,指出各自的特点和不足,交流开发过程中的收获和 体会。

下载数据库试题及课后答案(精选五篇)word格式文档
下载数据库试题及课后答案(精选五篇).doc
将本文档下载到自己电脑,方便修改和收藏,请勿使用迅雷等下载。
点此处下载文档

文档为doc格式


声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:645879355@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。

相关范文推荐

    数据库试题及答案(最终五篇)

    《数据库技术与应用》样题 一、选择题( 共 30 分,1--20 每小题 1 分,21—25 每小题 2 分。下列各题 A)、B)、 C)、D)四个选项中,只有一个选项是正确的 ) 1 在 SQL Server 中,关......

    2012-2011互联网数据库试题及答案

    全国2011年4月高等教育自学考试 互联网数据库试题 课程代码:00911 一、单项选择题(本大题共15小题,每小题2分,共30分) 在每小题列出的四个备选项中只有一个是符合题目要求的,请......

    数据库试题及答案(精选5篇)

    简答题部分: 2011.12.15 1. 设有关系模式:学生修课管理(学号,姓名,所在系,性别,课程号,学分,成绩),设一名学生可以选修多门课程,一门课程可以被多名学生选修,一名学生有唯一的所在系,每门......

    数据库试题及答案(样例5)

    一、填空 1.数据模型分为(层次模型 )和( 网状模型)、(关系模型)。 2.数据库系统(DBS)是一个由(外模式)、(模式)、(内模式)组成的多级系统结构。 3.数据库管理系统提供了4个方面的数据控制......

    数据库试题及答案很好的程序设计

    笔试样卷一 参考答案 一、简答题(25分) 2.设有三个关系 S (SNO, SNAME, AGE, SEX, SDEPT) SC (SNO, CNO, GRANDE) C (CNO, CNAME, CDEPT, TNAME) 试用关系代数表达式表示下列查......

    数据库试题及答案(优秀范文5篇)

    数据库练习题 第一章 一、单项选择题 1. 在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。在这几个阶段中,数据独立性最高的是阶段。 A. 数据......

    ACCESS数据库考试试题及答案2

    西安欧亚学院2010-2011学年第二学期考试试卷 专业:课程:数据库技术应用年级:09/10级 题号一二三四五六总分 得分评卷人得分一、单项选择题(本大题共25小题,每小题1分,共25分)在每小......

    SQL Server数据库试题七及答案

    SQL Server数据库试题七及答案 一.单项选择题(每题2分,计30分) 1._______是数据库系统的核心,它负责数据库的配置、存取、管理和维护等工作。(c ) A、操作系统 B、关系模型 C、数......