数据库复习-专升本附答案(EK-绝密版)_第1页
数据库复习-专升本附答案(EK-绝密版)_第2页
数据库复习-专升本附答案(EK-绝密版)_第3页
数据库复习-专升本附答案(EK-绝密版)_第4页
数据库复习-专升本附答案(EK-绝密版)_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

一 题型及分值一 题型及分值 1 填空题 10 小题 10 分 2 选择题 10 小题 20 分 3 问答与分析题 4 小题 30 分 4 综合题 2 小题 40 分 二 知识要点二 知识要点 一 关系模型的基本概念 一 关系模型的基本概念 例 1 学生社团可以接纳多名学生参加 但每个学生只能参加一个社团 从社团到学生 之间的联系类型是 例 2 层次模型不能直接表示 A 1 1 联系 B 1 n 联系 C m n 联系 D 1 1 和 1 n 联系 例 3 在三大传统的数据模型中 具有严格的数学理论基础的是 模型 例 4 数据库的数据独立性包括逻辑独立性和 二 关系代数运算 二 关系代数运算 例 1 五种基本关系代数运算是 A A 和 B 和 C 和 D 和 例 2 在关系代数中 除法运算由基本运算符 C 组成 A 和 B 和 C 和 D 和 例 3 设关系 R 和 S R S 的运算等价于 B A S R S B R R S C R S S D R R S 例 4 在关系代数中 连接运算 由基本运算符 C 组成 A 和 B 和 C 和 D 和 例 5 设关系 R 和 S 的属性个数分别为 r 和 s 则 R S 操作结果的属性个数为 元组个数为 例 6 设有如下关系 关系代数表达式 R S 的运算结果是 例 7 已知有如下三个关系 STUDENT 学号 姓名 性别 年龄 专业 GRADE 学号 课程号 成绩 COURSE 课程号 课程名 学分 课时 现有如下表达式 学号 姓名 STUDENT 学号 课程号 GRADE 课程号 COURSE 请用汉语句子写出该表达式表达的查询 并写出与该表达式对应的 SQL 语句 答 1 选修了全部课程的学生的学号和姓名 2 select sno sname From student Where not exists select From course Where not exists select From sc Where sno student sno and cno o 三 数据库的完整性 三 数据库的完整性 1 关系的三类完整性约束 2 触发器 例 1 关系模式的三类完整性约束条件分别是 参照完整性约束和用户 定义完整性约束 例 2 在 SQL Server 中 在视图上可以定义 类型的触发器 例 3 试举例说明在视图上创建 instead of 触发器能够使得视图具备可更新功能 答 如果一个视图涉及到计算列 那么该视图为不可更新视图 创建 books 表 create table books bookKey int identity 1 1 bookName nvarchar 10 not null Color nvarchar 10 not null ComputedCol as bookName Color Pages int 在 books 表上创建视图 包含基表中所有列 create view uv books as select bookKey bookName Color ComputedCol Pages from books 视图 uv books 包含计算列 为不可更新视图 在视图 uv books 上创建 instead of 触发器 create trigger tr uv books on uv books instead of insert as begin insert into books select bookName Color Pages from inserted end 往视图 uv books 上插入一行代码 完成对基表的插入 insert into uv books bookKey bookName Color ComputedCol Pages values 4 数据库原理 黄色 白色 200 从而验证了视图 uv books 为可更新视图 例 4 已知 S sno sname ssex sdept sage SC sno sname cno grade 请编写一个触发器 当 S 表中的 sname 字段值发生变化时 SC 对应的 sname 字段值也相应改变 create trigger trgInS on S after update as begin if update sname begin updateSC set sname select sname from inserted where sno select sno from inserted end end 四 四 SQL 语句语句 1 数据查询及更新 2 索引 3 视图 4 存储过程 游标 例 1 有职工表 EMP 和部门表 DEPT 如图所示 其中有下划线的属性为主键 有波浪线 的属性为外键 下面操作不能正确执行的是 A 检索部门号为 D05 的职工号 B 将 EMP 表中职工 李路 的部门号改为空值 C 删除职工 崔浩 的记录 D 在 EMP 表中插入记录 E18 D05 王莹 EMP DEPT 职工号 部门号 职工名 E01 D03 李路 E25 D01 武明 E19 D04 崔浩 E32 D01 李颖 例 2 已知两个关系如下 假设 R 的主键是 A S 的主键是 D 在关系 S 的定义中包含外键子句 FOREIGN KEY A REFERENCES R A 下列 SQL 语句不能成功执行的是 A DELETE FROM R WHERE A 2 B DELETE FROM R WHERE A 3 C DELETE FROM S WHERE A 1 D DELETE FROM S WHERE A 2 例 3 什么是存储过程 存储过程有哪些优点 答 存储过程是用户完成某项特定任务的一组预编译好的 SQL 语句 优点 1 模块化编程 2 快速执行 3 减少网络通信量 4 预防 SQL 语 句的注入攻击 例 4 什么是物化视图 试分析物化视图与普通视图的区别 答 物化视图指的是存放 SQL 语句对应查询结果的视图 区别 1 普通视图只存放视图的定义 物化视图存放的是实际的查询数据 2 使用物化视图的查询效率高于普通视图 3 物化视图需要占用较大的存储空间 4 当基表中的数据发生变化时 需要刷新物化视图 例 5 一个 SQL 语句原则上可产生或处理一组记录 而主语句一次只能处理一个记录 为此必须协调两种处理方式 这是通过使用 游标 机制来解决的 部门号 部门名 D01 研发部 D02 市场部 D03 人事部 D04 财务部 RABC 1b1c1 2b2c2 3b1c1 SDEA d1e11 d2e21 d3e12 五 关系数据理论 五 关系数据理论 1 函数依赖 完全函数依赖 部分函数依赖 传递函数依赖 2 三大范式 3 反范式设计 例 1 在关系数据库中 从关系规范化的意义看 如果关系 R 中的非主属性对码有传递 函数依赖 那么 R 最高是 范式 例 2 设有关系模式 R A B C D 其上的函数依赖集合 F B A BC D 则 R 最高是 范式 例 3 在关系模式 选课 学号 课程号 考试次数 成绩 中 假设一个学生可以参 加多门课程的多次考试 该关系模式的码是 例 4 关系数据库的规范化理论主要解决的问题是 A 如何构造合适的数据逻辑结构 B 如何构造合适的数据物理结构 C 如何构造合适的应用程序界面 D 如何控制不同用户的数据操作权限 例 5 一个只满足 1NF 的关系模式 可能存在哪些方面的问题 答 数据冗余 插入异常 删除异常和修改异常 例 6 关系模式 R 球员编号 篮球比赛场次 进球数 球队名 队长 用来表示我校 举行的各系篮球比赛 规定每个球队只有一名队长 1 试说明 R 不是 2NF 的理由 并将 R 分解为 2NF 的模式集 答 关系 R 的码是 球员编号 篮球比赛场次 该关系的函数依赖集如下 球员编号 篮球比赛场次 进球数 球员编号 球队名 球队名 队长 即存在非主属性 球员编号 队长 对码的部分函数依赖 因此 R 不是 2NF 将 R 分解为 2NF 后的结果如下 R1 球员编号 篮球比赛场次 进球数 R2 球员编号 球队名 队长 2 将 R 分解为 3NF 模式集 答 R1 球员编号 篮球比赛场次 进球数 R2 球员编号 球队名 R3 球队名 队长 例 7 就下图给出的关系 R 回答问题 R SNOCNOCTITLESNAMESLOCAGRADE 80152C1OS 王平 D170 80153C2DB 高升 D285 80154C1OS 王平 D186 80154C3AI 杨洋 D372 80155C4CL 高升 D292 1 关系 R 为几范式 为什么 2 是否存在删除操作异常 若存在 则说明是在什么样情况下发生的 3 将它分解成高一级范式 分解后的关系是如何解决分解前可能存在的删除异常问题 的 例 8 已知点评网的后台数据库中存在以下两个关系 帖子表 帖子 ID 帖子标题 会 员 ID 会员表 会员 ID 会员昵称 会员等级 请回答以下问题 1 已知 帖子 ID 为自增列字段 请写出查询最新的 10 个帖子的标题以及会员昵 称的查询语句 答 SELECT TOP 10 N 帖子标题 U 会员昵称 N 会员 ID FROM 帖子表 N INNER JOIN 会员表 U ON N 会员 ID U 会员 ID ORDER BY N 帖子 ID DESC 2 为了提高第一小题的 SQL 语句的查询速度 您会如何重新设计数据库表 并说明 原因 答 当帖子表和会员表中涉及到大量记录时 上述的查询难以满足用户对于网页速度的要 求 为了提高查询速度 考虑 反范式设计 即在帖子表里面添加冗余字段 会员昵称 这样就可以通过下面的语句达到同样的查询目的 SELECT TOP 10 帖子标题 会员昵称 会员 ID FROM 帖子表 ORDER BY 帖子 ID DESC 例 9 请简述范式对查询的影响 答 对查询的利 1 减少数据冗余 数据更为紧凑 2 表的行数少 排序 索引更为迅速 3 由于多表 多个聚集索引成为可能 对查询的弊 使得查询数据分离在多张表中 增加了查询的复杂性 六 数据库设计 六 数据库设计 例 1 概念结构设计阶段得到的结果是 A 数据字典描述的数据需求 B E R 图表示的概念模型 C 某个 DBMS 所支持的数据模型D 包括存储结构和存取方法的物理结构 例 2 单个用户使用的数据视图的描述称为 A 外模式 B 概念模式 C 内模式 D 存储模式 例 3 在合并分 E R 时 需完成消除命名冲突的工作 使用 视图 机制可以重新定义某 些属性名 使其与用户习惯一致 例 4 试举例说明存储过程能够在一定程度上预防 SQL 语句的注入攻击问题 答 假设数据库中有一个关系 student sno sname sage ssex 在连接数据库后 使用字符串拼接的方式查询指定学号的学生信息 其中 txtSno Text 代表用户往文本框中输入的学号 String sqlStr select from student where sno txtSno Text Trim 如果用户往文本框中输入字符串 or 1 1 该语句将成为 select from student where sno or 1 1 即执行结果为 student 表中的全部记录 而如果在 student 表上创建如下存储过程 Pr Student 其中 sno 为接受用户输入的学 号信息 Create procedure Pr Student sno char 5 As Select from student sno sno 然后在应用程序中使用如下语句调用存储过程 SqlCommand command new SqlCommand Pr Student sqlCon command CommandType CommandType StoredProcedure command Parameters AddWithValue sno sno 当用户输入字符串 or 1 1 将在数据库中查找 sno 为 or 1 1 的学生信息 输 出结果将为空 通过上例说明了使用存储过程能够预防 SQL 语句的注入攻击 七 事务和数据库恢复 七 事务和数据库恢复 例 1 事务的 ACID 特性指的是什么 例 2 对于事务故障的恢复 恢复子系统将结合日志文件撤销事务 具体做法是 向 扫描日志文件 对事务中的每个操作执行逆向操作 例 3 请分析故障子系统对于下图所示的事务所采取的恢复策略 Tc 检查点Tr 系统故障 T1 T2 T3 T4 T5 Tc 检查点Tr 系统故障 T1 T2 T3 T4 T5 答 T1 为检查点之前已经提交的事务 因此不执行任何操作 T2 和 T4 为在检查点后故障 点前提交的事务 它们对数据库所做的修改在故障发生时还可能在缓冲区中 尚未写入数 据库 因此进行 REDO 操作 T3 和 T5 在故障发生时还未完成 因此予以撤销 例 4 你所在的企业的数据库中拥有一套完整的备份策略 每周日晚上执行完整备份 每天晚上执行差异备份 每天 12 点 14 点 16 点执行事务日志备份 某个周三的下午 13 点 用户报告说不能访问数据库 作为 DBA 你检查时发现数据 库发生了严重的故障 存储数据库的硬盘无法正确工作 这时 你会如何处理 答 为服务器更换新的硬盘 使用存储在另外一个盘上的备份文件进行故障恢复 先使用 上周日晚的完整备份文件进行还原 再使用周二晚上的差异备份文件进行还原 最后使用 当天中午 12 点的事物日志备份进行还原 八 综合题 八 综合题 1 设某商业集团数据库中有三个实体集 商店 实体集 其中的属性有商店编号 商店 名 地址等 商品 实体集 其中的属性有商品号 商品名 规格 单价等 职工 实体集 其中的属性有职工编号 姓名 性别 业绩等 商店与商品之间存在 销售 联系 每个商店可销售多种商品 每种商品也可放在多 个商店销售 每个商店销售一种商品 有月销售量 商店与职工之间存在着 聘用 联系 每个商店的职工人数应该在 20 100 人之间 每个职工只能在一个商店工作 商店聘用职工 有聘用期和月薪 1 试画出 E R 图 答 商店 商品 职工 销 售 聘 用 单价 商店编号 商店名地址 月薪 聘期 职工编号姓名 性别 业绩 商品号 商品名规格 月销售量 M 1 M N 2 将 E R 图转换成关系模型 答 商店 商店编号 商店名 地址 职工 职工编号 姓名 性别 业绩 商店编号 聘期 月薪 商品 商品号 商品名 规格 单价 销售 商店编号 商品号 月销售量 2 设有学生运动会模型 语义如下 1 有若干班级 每个班级包括 班级号 班级名 专业 人数 2 每个班级有若干运动员 运动员只能属于一个班 运动员信息包括 运动员号 姓名 性别 年龄 3 有若干比赛项目 包括 项目号 名称 比赛地点 4 每名运动员可参加多项比赛 每个项目可有多人参加 5 要求能够公布每个比赛项目的运动员名次与成绩 6 要求能够公布各个班级团体总分的名次和成绩 解题要求 1 画出每个实体及其属性关系 实体间实体联系的 E R 图 答 2 根据试题中的处理要求 把 E R 图转化为关系数据逻辑模型 包括各个表的名称和属 性 并指出每个表的主键和外键 答 关系模式如下 a 班级 班级号 班级名 专业 人数 主键 班级号 b 运动员 运动员号 姓名 性别 年龄 班级号 主键 运动员号 外键 班级号 c 项目 项目号 项目名 比赛地点 主键 项目号 d 比赛 运动员号 项目号 成绩 名次 得分 主键 运动员号 项目号 外键 运动员号 项目号 3 试用关系代数描述 检索出参加 跳高 比赛项目的运动员姓名 答 姓名 项目名 跳高 运动员比赛项目 4 为 比赛 表中的 成绩 字段添加完整性规则 成绩的值只能在 0 100 的范围内 答 alter table 比赛 add constraint CK grade check 成绩 0 and 成绩 18 and 年龄 22 的查询速 度 你会如何创建索引 请写出创建索引的语句 答 create index 年龄 姓名 on 运动员 年龄 姓名

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论