欢迎来到天天文库
浏览记录
ID:50025705
大小:80.50 KB
页数:23页
时间:2020-03-07
《Oracle Database 10g基础教程(第二版) 教学课件 作者 978-7-302-15311-5ch12.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第12章视图本章概述本章要点教学过程1本章概述视图是一个逻辑表,是查看表的一种方式。视图是对根据预定义的选择标准、由一个或者多个行的集合建立起来的动态表的静态定义。视图可以用来定义来自一个或者多个表的行和列的多种连接。通过视图可以查看表中的数据。如果视图很大,则能看到表中的许多数据;如果视图很小,那么就只能看到表中的有限信息。本章将介绍与视图管理有关的各种技术。2本章要点了解视图的基本概念和类型理解关系视图的特点掌握如何管理关系视图理解内嵌视图的应用特点认识对象视图的作用掌握物化视图的特点3教学过程12.1概述12.2关系视图12.3内嵌视图12.4对象
2、视图12.5物化视图4教学过程12.1概述12.2关系视图12.3内嵌视图12.4对象视图12.5物化视图512.1概述使用视图有许多优点,例如:集中用户使用的数据掩码数据库的复杂性简化权限管理为向其它应用程序输出而重新组织数据在Oracle系统中,有4种类型的视图,即关系视图、内嵌视图、对象视图和物化视图。每一种类型的视图都有自己的特点。6教学过程12.1概述12.2关系视图12.3内嵌视图12.4对象视图12.5物化视图712.2关系视图关系视图实际上是经过存储的查询,可以将其输出看作是一个表。它就是基于关系数据的存储对象。可以将视图看作是虚拟表,可
3、以像查询表一样查询视图。本节将详细介绍与关系视图相关的内容。8创建视图可以使用createview语句创建视图。当创建视图时,视图的名称必须符合命名规则。指定视图所有者的姓名是可选项。因为视图的外表和表的外表是一样的,因此,为了区别表和视图,应该使用一种命名机制,使人容易分辨出视图和表。使用createview语句创建视图的部分语法格式如下:create[orreplace][force
4、noforce]view[user.]view_name[column1[,column2]…]asquery[withcheckoption[constraintco
5、nstraint_name][withreadonly]9检索视图的定义所有的视图定义都存储在数据库的数据字典中。用户可以查询数据字典中的适当视图来检索视图的定义,也就是构成视图的查询。user_views数据字典视图包含了视图的定义信息。10改变视图的定义是否可以相同的名称自由地重建新的视图呢?完全可以。重新创建视图的方法就是使用createorreplace命令。如图12-6所示的操作过程使用了createorreplace命令重建computeSalary视图,并且使用desc命令查看重建后的视图结构。11删除视图如果不再需要视图了,那么可以删除视
6、图。删除视图可以使用dropview名称,如图12-7所示的是删除computeSalary视图的操作过程。删除视图之后,如果再次使用它时,系统就会报出对象不存在的错误。视图被删除之后,与该视图有关的权限也随之删除。即使新建创建了该名称的视图,视图的权限也需要重新赋予。12视图中的约束视图不仅可以限制能够看到的列,而且还能够限制所返回的行。如果需要创建只能够显示薪水超过1500元的员工的视图,可以使用如图12-8所示的代码。从执行代码后返回的结果可以看到,有9个员工的薪水超过了1500元。如果需要创建一个可以查看公司中每一种工作类型和相应员工数量的视图,
7、那么可以执行如图12-9所示的操作。视图可以隐藏查询的复杂性。从图12-9可以看出,当用户使用job_total查询每一种工作类型的员工数量时,用户没有必要知道这些数据是如何一步步地计算出来,只需查询job_total视图即可。13联接视图用户通过视图查看数据的目的,是希望通过视图查看所需要的数据。这些数据可能存在于一个基表中,也可能存在于多个基表中。前面创建的视图都是来自于一个基表。实际上,视图还可以来自多个基表。也就是说,通过连接多个基表也可以创建视图。通过创建基于多个基表的视图,可以查看到比单个基表更多的数据。emp表包含了雇员姓名、工作、薪水等信
8、息,dept表包含了部门名称、部门所在位置等信息。如果用户希望通过一个视图,既可以查看到雇员的基本信息,也可以查看到部分的基本信息,那么可以使用如图12-10所示的联接视图。14验证视图当创建视图时,Oracle将会验证视图的有效性。以后,改变基本表的特性有可能导致视图无效。例如,以下操作将导致视图无效:改变列的名称,或从基本表或视图中完全删除列。删除构建视图的基本表或视图。改变基本表或视图,使其无效,这样将导致视图变得无效。为了解决上述问题,可以使用alterviewview_namecompile命令重新编译视图,或者使用createorreplac
9、eview命令重新创建视图,或者修正视图所基于的基本表或视图。15通过视图更新和
此文档下载收益归作者所有