首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载 | ||
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试 MPA考试 | 中科院 |
||
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT 新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语 |
||
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证 华为认证 | Java认证 |
||
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格 报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师 人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平 驾驶员 | 网络编辑 |
||
卫生资格 | 执业医师 | 执业药师 | 执业护士 | ||
会计从业资格考试(会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师 注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师 |
||
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师 质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师 设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师 城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师 |
||
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏 |
●试题3
阅读以下说明和表,回答问题l至问题4,将解答填入答题纸的对应栏内。
【说明】
某医院信息管理系统的需求分析和部分关系模式设计的结果描述如下:
(1)医院有多个部门,每个部门有一名负责人、一间办公室、一部电话、多名医生(护士),每个医生(护士)最多属于一个部门,负责人也是一名医院医生(护士)。
(2)医院医生(护士)的月工资大于等于1000元且小于等于8000元。
(3)数据库的部分关系模式设计如下:
医护人员(编号,姓名,月工资,部门号,办公室,电话)
部门(部门号,部门名,负责人代码,任职时间)
(4)“医护人员”和“部门”的关系示例分别见表7.3和表7.4。
表7.3 “医护人员”关系
编号 | 姓名 | 月工资 | 部门号 | 办公室 | 电活 |
60801 | 汪俊华 | 1000 | 3 | A座201 | 68831226 |
60802 | 杨晓军 | 3200 | 1 | A座202 | 68831227 |
60803 | 王晓华 | 1200 | 2 | B座202 | 68831256 |
60804 | 吕靖原 | 3200 | 4 | A座301 | 6883 1258 |
60805 | 牟雪松 | 2800 | 3 | B座302 | 68831266 |
60806 | 周黎 | 4300 | 2 | A座202 | 6883 1227 |
60807 | 程文驰 | 0 | Null |
部门号 | 部门名 | 负责人代码 | 任职时间 |
1 | 财务部 | 60802 | 2001—8—52 |
2 | 住院部 | 60803 | 2002—6—33 |
3 | 医药部 | 60805 | 2002—6—34 |
4 | 门诊部1 | 60810 | 2003—8—15 |
5 | 门诊部2 | 60821 | 2004—6—3 |
【问题1】
根据上述说明,请给出
(1)“医护人员”关系模式的主键和外键。
(2)“部门”关系模式的主键和外键。
【问题2】
(1)用SQL定义“医护人员”关系模式,请在空缺处填入正确的内容。
Create Table“医护人员”(编号CHAR(5)(a),
姓名CHAR(8),
月工资NUMBER(4),
部门号CHAR(1),
办公室CHAR(20),
电话CHAR(8),
(b)(部门号),
CHECK(月工资>=1000 AND月工资<=8000));
(2)针对人数大于等于2的部门创建视图D—View(Dept,D—num,D—Totals,D—AvgPay),其中, Dept为部门号,D—num为部门人数,D_Totals为工资总数,D—AvgPay为平均工资,请在空缺处填入正确的内容。
Create View D—View(Dept,D—num,D_TotMs,D—AvgPay)As
(Select部门号,(C)
from医护人员
(d)count(*)>=2 WHERE部门号IS NOT NULL);
【问题3】
对于表7.3、表7.4所示的“医护人员”和“部门”关系,请指出下列各行是否可以插入“医护人员”关系,为什么?
表7.5
60811 | 芦峰 | 800 | 1 | A座201 | 68831226 |
60802 | 李晓啸 | 3500 | 2 | B座202 | 68831236 |
60812 | 高亚南 | 2600 |
原来的“医护人员”关系模式存在什么问题?在不增加新关系模式的前提下,请给出修改后的“医护人员”和“部门”关系模式。
【问题1】解答:
(1)“医护人员”关系模式的主键和外键分别是编号和部门号。
(2)“部门”关系模式的主键是部门号或部门名,外键是负责人代码。
【问题2】解答:
编号是主键,所以(a)处填入PRIMARY KEY。部门号是外键,所以(b)处填入FOREIGN KEY(部门号)REFERENCES部门。
根据字段要求,(c)处填入Count(*),Sum(月工资),Avg(月工资),(d)处填入GROUP BY部门号HAVING。以上答案中的单词不区分大小写。
【问题3】解答:
第一行不能插入,原因是他的工资小于1000。
第二行也不能插入,因为编号60802已经存在于表中。
第三行可以插入,尽管后三个属性为空,它表示该人员尚未分配部门。
【问题4】解答:
“医护人员”关系模式存在的问题有,①数据冗余,同一部门有多少员工,部门的办公司和电话就要重复记录多少次。②数据一致性,当某部门的办公司变化时,可能会导致某些人的属性修改了,而某些未修改。
将关系模式修改为:
医护人员(编号,姓名,月工资,部门号)
部门(部门号,部门名,负责人代码,任职时间,办公室,电话)
北京 | 天津 | 上海 | 江苏 | 山东 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
广东 | 河北 | 湖南 | 广西 | 河南 |
海南 | 湖北 | 四川 | 重庆 | 云南 |
贵州 | 西藏 | 新疆 | 陕西 | 山西 |
宁夏 | 甘肃 | 青海 | 辽宁 | 吉林 |
黑龙江 | 内蒙古 |