大连海事大学
数据库原理课程实验大纲
实验名称: 实验五 视图 实验学时: 2
适用专业:
实验环境: SQL.rve2008
执 笔 者: 编写日期:
1 实验目的
(1) 掌握SQL视图语句的基本使用方法,如CREATE VIEW、DROP VIEW。
(2) 掌握视图更新、WITH CHECK OPTION等高级功能的使用。
2 实验内容
2.1 掌握SQL视图语句的基本使用方法
(1) 创建视图(省略视图列名)。
(2) 创建视图(不能省略列名的情况)。
(3) 删除视图(RESTRICT / CASCADE)。
2.2 掌握视图更新和WITH CHECK OPTION的高级使用方法
炒饭大全
(1) 描写老师的优美句子创建视图(WITH CHECK OPTION),并利用INSERT、DELETE和UPDATE语句加以验证。
(2) 创建一个行列子集可更新视图,并利用INSERT、DELETE和UPDATE语句加以验证。
(3) 创建一个不可能更新的视图,并利用更新语句验证该视图不可更新。
3 实验要求
(1) 深入复习教材第三章SQL有关视图语句。
(2) 根据书上的例子,针对TPCH数据库模式设计各种视图语句,每种类型视图语句至少要设计一个,描述清楚视图要求,运行你所设计的视图语句,并截图相应的实验结果,每幅截图并要有较为详细的描述。也可以按照附1所列示例做实验。
(3) 哀郢原文及翻译实验步骤和实验总结中要详细描述实验过程中出现的问题、原因和解决方法。
(4) 思考题:KingbaES把视图的定义存储在那个系统表中?如何查看某个视图的定义?
4 实验步骤
4.1 掌握SQL视图语句的基本使用方法
(1) 创建视图(省略视图列名)。
创建一个“海大汽配”供应商供应的零件视图V_DLMU_PartSupp1,要求列出供应零件的编号、零件名称、可用数量、零售价格、供应价格和备注等信息。
CREATE VIEW V_DLMU_PartSupp1(PARTKEY,NAME,AVAILQTY,RETAILPRICE,SUPPL
YCOST,COMMENT)
AS
SELECT P.PARTKEY,P.NAME,PS.AVAILQTY,P.RETAILPRICE,PS.SUPPLYCOST,P.COMMENT
FROM PART P,PARTSUPP PS
WHERE P.PARTKEY=PS.PARTKEY AND PS.SUPPKEY喉咙痒干咳怎么治 IN
(SELECT SUPPKEY
FROM SUPPLIER S
WHERE S.NAME='海事大学')
(2) 创建视图(不能省略列名的情况)。
创建一个视图V_CustAvgOrder,按顾客统计平均每个订单的购买金额和零件种类数量,要求输出顾客编号,姓名,平均购买金额和平均购买零件种类数量。
CREATE VIEW V_CustAvgOrder(CUSTKEY,NAME,AVGPRICE,AVGQUAN)
AS
SELECT O.CUSTKEY,C.name,AVG(O.TOTALPRICE),AVG(L.QUANTITY)
FROM CUSTOMER C,ORDERS O,lineitem L
WHERE C.CUSTKEY=O.CUSTKEY AND L.ORDERKEY=O.ORDERKEY
GROUP BY O.CUSTKEY,c.name(这里容易出错,结果必须在GROUP中出现)使用GROUP BY子句后,SELECT子句的目标列表达式列表中只能出现分组属性和集函数
(3) 删除视图(RESTRICT / CASCADE)。
创建顾客订购零件明细视图V_CustOrdDetails,要求列出顾客编号、姓名、购买零件数、金额;然后在该视图的基础上,实现(2)中的视图V_CustAvgOrder;
然后删除利用RESTRICT选项删除视图V_CustOrdDetails,观察现象,并解释原因。
利用CASCADE选项删除视图V_CustOrdDetails,观察现象,并检查V_CustAvgOrder是否存在?解释原因?
CREATE华科是哪个大学 VIEW V_CustOrdDetails(CUSTKEY,NAME,QUANTITY,TOTALPRICE)
AS
SELECT C.CUSTKEY,C.NAME,L.QUANTITY,O.TOTALPRICE
退机票手续费FROM CUSTOMER C,ORDERS O,LINEITEM L
WHERE C.CUSTKEY=O.CUSTKEY AND O.ORDERKEY=L.ORDERKEY
利用RESTRICT删除视图时显示出错,因为在V_CustOrdDetails的基础上建立了V_CustAvgOrder。使用CASCADE删除显示V_CustOrdDetails和V_CustAvgOrder不存在
4.2 掌握视图更新和WITH CHECK OPTION的高级使用方法
(4) 创建一个行列子集可更新视图,并利用INSERT、DELETE和UPDATE语句加以验证。
创建一个“海大汽配”供应商供应的零件视图V_DLMU_PartSupp2,要求列出供应零件的编号、可用数量和供应价格等信息。
然后通过该视图分别增加、删除和修改一条“海大汽配”零件供应记录,验证该视图是否是可更新的?
CREATE VIEW V_DLMU_PartSupp2(PARTKEY,AVAILQTY,SUPPLYCOST)
AS
SELECT PARTKEY,AVAILQTY,SUPPLYCOST
FROM PARTSUPP
WHERE SUPPKEY IN
(SELECT SUPPKEY
FROM SUPPLIER S
WHERE S.腹心之疾NAME='海事大学')
UPDATE V_DLMU_PartSupp2
SET SUPPLYCOST=2
WHERE PARTKEY=1
DELETE
FROM V_DLMU_PartSupp2
WHERE PARTKEY=1
插入受限,无法更新
INSERT INTO V_DLMU_PartSupp2
VALUES(4,23434,3)
(5) 创建视图(WITH CHECK OPTION操干视频),并利用INSERT、DELETE和UPDATE语句加以验证。