数据库原理实验报告实验四视图与索引
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
《数据库原理》实验报告
题目:实验四视图与索引学号姓名班级日期
2016、
10.20
一、实验内容、步骤以及结果
1.在Student数据库中,利用图形用户界面,创建一个选修了“数据库原理”课程并且就是1996年出生得学生得视图,视图中包括学号,性别,成绩三个信息。(5分)
2.用两种不同得SQL语句创建第五版教材第三章第9题中要求得视图(视图名:V_SP J)(10分,每种方法5分)、
-—第一种方法
CREATE VIEW V_SPJ AS
SELECT sno,pno,qty FROM SPJ
WHERE jno=(
SELECT jno FROM J
WHERE jname =’三建’
);
GO
-—删除建好得视图
DROPVIEW V_SPJ;
GO
—-第二种方法
CREATE VIEW V_SPJAS
SELECT sno,pno,qty
FROM SPJ,J
WHERE J。jno=SPJ。jno AND J、jname='三建’;
3.用SQL语句完成第五版教材第三章第11题中得视图查询(10分,每小题5分)。
11、请为三建工程项目建立一个供应情况得视图,包括供应商代码(SNO)、零件代码(PNO)、供应数量(QTY)。
针对该视图VSP完成下列查询:
(1)找出三建工程项目使用得各种零件代码及其数量。
(2)找出供应商S1得供应情况。
4.用SQL语句完成视图得数据更新。(15分,每题5分)
(1)给视图V_SPJ中增加一条数据、
提示:
-SPJ表中JNO允许为空时,数据可以插入基本表,此时JNO为NULL,由于JNO 为NULL,所以视图中没有该条数据。
-SPJ表中JNO不能为空时,可以使用instead of触发器实现。
(2)修改视图V_SPJ中得任意一条数据得供应数量、
(3)删除视图V_SPJ中得任意一条数据(注意所创建视图可以视图消解时,才能正常删
除,否则会删除失败;也可以考虑用instead of触发器实现)、
5.用图形用户界面对Student数据库中C表得Cno字段创建一个降序排列得唯一索引,索引名称IX_CNo。(5分)
6.使用SQL语句对Student数据库完成以下得索引操作。(15分,每题5分)
(1)在C表得CName属性上创建一个非唯一性得聚簇索引,索引名IX_CName。(提示:创建这个聚簇索引之前,需要首先删除C表得主键约束。SQL Server中,给某张表指定主键时,会自动创建为主属性一个聚簇索引、)
(2)在SC表上创建一个名为IX_Cnosno得非聚簇复合索引,该索引就是针对sn
o,cno属性集建立得升序索引。
(3)删除C表得索引IX_CName。
7.自己设计一个实验验证索引对数据库查询效率得提升作用。(40分)
(提示:需要数据量比较大得情况下才容易进行对比)
采用一卡通消费记录作为实验数据,一共812条记录,
将交易发生时间设置为主键,建立升序索引,查询某天得消费记录,与未建立索引时相比较。每种情况查询5次,计算平均时间、
单位:毫秒
第1次第2次第3次第4次第5次平均时间
不使用索引190 10131007。2
使用索引 1 1 .2 通过数据可以瞧出,建立索引后查询平均时间确实较没有索引时短、
二、实验中出现得问题以及解决方案(对于未解决问题请将问题列出来)
除了标题内容以外,该部分内容中还可以写对于实验得一些感受,建议,意见等。
问题:在Student数据库中,利用图形用户界面,创建一个选修了“数据库原理”课程并且就是1996年出生得学生得视图,因为sbirth得类型就是date,不能用LIKE'1996%’命令进行检索。
解决方案:使用BETWEEN ‘1996-1-1’ AND ‘1997-1—1’表达式。如下图:
批阅者:
批阅日期:
实验成绩:
批注: