数据库作业(3)(9页).doc
-数据库作业(3)-第 8 页兰州交通大学数据库原理及应用作业学 号:201108604 姓 名:贺庆杰 指导教师:司徒国强 成 绩: 概念基础部分:简述数据库管理系统的功能。答:数据库管理系统是数据库系统的核心软件 ,一般说来,其功能主要包括以下 5 个方面。(1) 数据定义和操纵功能 (2) 数据库运行控制功能(3) 数据库的组织、存储和管理 (4) 建立和维护数据库 (5) 数据通信接口解释关系模型的基本概念:关系、元组、属性、域、关系模式、候选关键字、主键、外键、主属性。答:关系:一个关系就是一张二维表。元组:二维表中的行称为元组,每一行是一个元组。属性:二维表的列称为属性,每一列有一个属性名,属性值是属性的具体值。域:是属性的取值范围。关系模式:对关系的信息结构及语义限制的描述称为关系模式,用关系名和包含的属性名的集合表示。候选关键字:如果在一个关系中,存在多个属性(或属性组合)都能用来唯一标识该关系中的元组,这些属性(或属性组合)都称为该关系的候选关键字或候选码,候选码可以有多个。主键:在一个关系的若干候选关键字中,被指定作为关键字的候选关键字称为该关的主键或主码。主属性:在一个关系中,包含在任何候选关键字中的各个属性称为主属性。外键:一个关系的某个属性(或属性组合)不是该关系的主键或只是主键的一部分,却是另一个关系的主码,则称这样的属性为该关系的外键或外码。6.某网上订书系统,涉及如下信息:(1)客户:客户号、姓名、地址、联系电话。(2)图书:书号、书名、出版社、单价。(3)订单:订单号、日期、付款方式、总金额。其中:一份订单可订购多种图书,每种图书可订购多本;一位客户可有多份订单,一份订单仅对应一位客户。(1)根据以上叙述,建立ER模型,要求标注联系类型(可省略实体的属性)。(2)根据转换规则,将ER模型转换成关系模型,要求标注每个关系模型的主键和外键(如果存在)。出版社1NMM客户订单拥有图书订购联系电话地址书号书名订单号日期付款方式客户号姓名数量总金额单价答:(1)ER模型(2)关系模式:客户(客户号,姓名,地址,联系电话,订单号)图书(书号,书名,出版社,单价)订单(订单号,日期,付款方式,总金额)订购(订单号,书号,数量)8.根据给定的关系模式进行查询。设有学生-课程关系数据库,它由三个关系组成,它们的模式是:学生S(学号S#,姓名SN,所在系SD,年龄SA)、课程C(课程号C#,课程名CN,先修课号PC#)、SC(学号S#,课程号C#,成绩G)。请用关系代数分别写出下列查询:(1)检索学生的所有情况。S#, SN, SD, SA(S)(2)检索学生年龄大于等于20岁的学生姓名。SN(SA20 (S)(3)检索先修课号为C2的课程号。 C#(PC#=C2 (C)(4)检索课程号C1的成绩为A的所有学生姓名。SN(C#=C1 G=A (SSC)(5)检索学号为S1的学生选修的所有课程名及先修课号。CN, PC#(S#=S1 (CSC)(6)检索年龄为23岁的学生所选修的课程名。CN(SA=23 (CSCS)10.简述数据库设计过程的各个阶段上的设计任务。答:需求分析的任务是通过详细调查现实世界要处理的对象(组织、 部门、 企业等), 充分了解原系统(手工系统或计算机系统)工作概况,明确用户的各种需求,然后在此基础上确定新系统的功能。概念设计阶段要做的工作不是直接将需求分析得到的数据存储格式转换为DBMS能处理的数据库模式,而是将需求分析得到的用户需求抽象为反映用户观点的概念模型。逻辑设计的主要目标是产生一个DBMS可处理的数据模型和数据库模式。该模型必须满足数据库的存取、一致性及运行等各方面的用户需求。将逻辑设计中产生的数据库逻辑模型结合指定的DBMS,设计出最适合应用环境的物理结构的过程,称为数据库的物理结构设计。根据逻辑和物理设计的结果,在计算机上建立起实际的数据库结构,并装入数据,进行试运行和评价的过程,叫做数据库的实施(或实现)。维护工作包括以下内容:数据库的转储和恢复;数据库的安全性和完整性控制;数据库性能的监督、分析和改造;数据库的重组织和重构造。12一个图书馆理系统中有如下信息:图书:书号、书名、数量、位置借书人:借书证号、姓名、单位出版社:出版社名、邮编、地址、电话、E-mail其中约定:任何人都可以借多种书,任何一种书可以被多个人借,借书和还书时,要登记相应的借书日期和还书日期;一个出版社可以出版多种书籍,同一本书仅为一个出版社所出版,出版社名具有唯一性。根据以上情况,完成如下设计:(1)设计系统的E-R图;(2)将E-R图转换为关系模式;(3)指出转换后的每个关系模式的主码。答:(1)E-R图1MNM借书人图书借阅书名数量位置借书证号姓名单位借书日期书号出版社出版E-mail电话出版社名邮编地址还书日期(2)和(3)关系模式图书(书号,书名,数量,位置,出版社名)借书人(借书证号,姓名,单位)出版社(出版社名,邮编,地址,电话,E-mail)借阅(书号,借书证号,借书日期,还书日期)T-SQL语句部分:14在“学生管理”数据库中建立“学生”、“课程”和“成绩”数据表,其中: 学生(学号CHAR(8),姓名CHAR(8),性别CHAR(2),出生日期DATATIME,邮政编码CHAR(6),住址VARCHAR(50),简历TEXT),其中学号为主键。 课程(课程号CHAR(4),课程名称VARCHAR(50),学分INT),其中课程号为主键。成绩(学号CHAR(8),课程号CHAR(4),期中成绩INT,期末成绩INT),其中学号与课程号的组合为主键。答: USE 学生管理 GO CREATE TABLE 学生 ( 学号 CHAR(8) PRIMARY KEY, 姓名 CHAR(8) NOT NULL, 性别 CHAR(8), 出生日期 DATATIME,邮政编码 CHAR(6),住址 VARCHAR(50),简历 TEXT USE 学生管理 GO CREATE TABLE 课程 ( 课程号 CHAR(4) PRIMARY KEY, 课程名称 VARCHAR(50) NOT NULL, 学分 INT USE 学生管理 GO CREATE TABLE 成绩( 学号 CHAR(8),课程号 CHAR(4),期中成绩 INT,期末成绩 INT,CONSTRAINT pk_js PRIMARY KEY(学号,课程号) 16. 在“学生”表中,查询前5条的所有记录。答:USE 学生管理 SELECT TOP 5 * FROM 学生18. 在“学生”表中查询班级不能重复的记录。 答:USE 学生管理 SELECT DISTINCT 班级 FROM 学生20在“成绩”表中查询期末成绩大于80的并期中成绩成绩大于70分的记录。 答:USE 学生管理 SELECT * FROM 成绩 WHERE 期末成绩>=80 AND 期中成绩>=7022在“学生”表中,查询学号为20060001,20060002, 20060003的学生的班级,性别。 答:USE 学生管理 SELECT 班级,性别 FROM 学生 WHERE 学号=20060001 OR 学号=20060002 OR 学号=2006000324在“学生”表中,查询姓刘或姓张同学的学号,姓名和班级的记录。 答:USE 学生管理 SELECT 学号,姓名,班级 FROM 学生 WHERE 姓名 like刘%OR姓名like张%26. 在“学生”表中,查询除了姓刘同学的所有记录。 答:USE 学生管理 SELECT * FROM 学生 WHERE 姓名 like刘%28. 在“学生”表中,查询出生日期在1985年内出生的所有女生的所有记录。 答:USE 学生管理 SELECT * FROM 学生 WHERE 出生日期=1985 AND性别=女 30在“成绩”表中,查询期中成绩在后4名同学的所有记录。 答:USE 学生管理 SELECT TOP 4 * FROM 成绩 ORDER BY 期中成绩 ASC32修改“成绩”表,添加“平时成绩”列,数据类型为int,默认值为0;再添加“总成绩”列,数据类型为int。 答:USE 学生管理 GO ALTER TABLE 成绩 ADD 平时成绩 int DEFAULT 0, ADD 总成绩 int34. 将学号为“20060004”的学生删除。 答:USE 学生管理 DELETE 学生 WHERE 学号=2006000436在“成绩”表中查询期中成绩大于80,且平时成绩为18分的记录。 答:USE 学生管理 SELECT * FROM 成绩 WHERE 期末成绩>=80 AND 平时成绩=1838从“学生”表中获取学生的学号、姓名、班级,从“成绩”表中获取学生的期中成绩和期末成绩。 答: USE 学生管理 SELECT 学生.学号, 学生.姓名, 学生.班级,成绩.期中成绩,成绩.期末成绩 FROM 学生 INNER JOIN成绩 ON 学生.学号=成绩.学号40在“成绩”表中查询高于期末成绩的平均成绩的行。 答:USE 学生管理 SELECT * FROM 成绩 WHERE 期末成绩> ( SELECT avg(期末成绩) FROM 成绩42.求选修C004课程的学生的平均年龄。答:SELECT AVG(年龄) FROM 学生,选课 WHERE 学生.学生号=选课.学生号 and 课程号=C00444.统计每门课程的学生选修人数,超过3人的课程才统计。要求输出课程号和选修人数,查询结果按人数降序排列,若人数相同,按课程号升序排列。 答:SELECT 课程号,COUNT(*) FROM 选课GROUP BY 课程号HAVING COUNT(*) >3ORDER BY COUNT(*) DESC, 课程号46.在选课表中检索成绩为空值的学生学号和课程号。 答:SELECT 学生号,课程号 FROM 选课 WHERE 成绩 IS NULL 48.求年龄大于所有女同学年龄的男学生姓名和年龄。答:SELECT 姓名,年龄 FROM 学生WHERE 性别=男 and 年龄 > all (SELECT 年龄 FROM 学生WHERE 性别=女)50.检索选修课程C002的学生中成绩最高的学生的学号。答:SELECT 学生号 FROM 选课WHERE 课程号=C002 and 成绩=(SELECT MAX(成绩) FROM选课 WHERE课程号=C002)52.检索选修4门以上课程的学生总成绩(不统计不及格的课程),并要求按总成绩的降序排列出来。答:SELECT 学生号,SUM(成绩) FROM 选课WHERE 成绩>=60GROUP BY学生号HAVING COUNT(*)>=4ORDER BY SUM(成绩) DESC54按照成绩表的总成绩列升序创建一个普通索引(非唯一、非聚集)。答:USE 学生管理 GO CREATE INDEX index_学生姓名 ON 成绩(总成绩)56创建存储过程,从课程表中返回指定的课程的信息。该存储过程对传递的参数进行模式匹配,如果没有提供参数,则返回所有课程的信息。答:CREATE PROCEDURE Pcourse name varchar(20) = '%'AS SELECT * FROM 课程WHERE 课程名 LIKE name58利用T-SQL扩展方式声明一个游标,查询学生表中所有男生的信息,并读取数据。关闭游标,最后释放游标。答:DECLARE N_Cursor CURSOR DYNAMIC FOR SELECT *FROM 学生WHERE 性别=男FETCN NEXT FROM N_CursorGOCLOSE N_CursorGODEALLOCATE N_CursorGO60. 简述数据库备份和还原的基本概念?答:数据库备份就是在某种介质上(磁盘、磁带等)创建完整数据库(或者其中一部分)的副本,并将所有的数据项都复制到备份集,以便在数据库遭到破坏时能够恢复数据库。 还原数据库是一个装载数据库的备份,然后应用事务日志重建的过程。