龙空技术网

从零开始学习Oracle之视图

ITPro进化论 117

前言:

此时朋友们对“oracle创建视图”大致比较关注,大家都需要分析一些“oracle创建视图”的相关内容。那么小编在网络上搜集了一些对于“oracle创建视图””的相关文章,希望姐妹们能喜欢,同学们一起来学习一下吧!

数据库中的视图是一个虚拟表。同真实的表一样,视图包含一系列带有名称的行和列数据。行和列数据来自由定义视图查询所引用的表,并且在引用视图时动态生成。

1.视图概述

视图是从一个或者多个表中导出的,视图的行为与表非常相似,但视图是一个虚拟表。在视图中用户可以使用SELECT语句查询数据,以及使用INSERT、UPDATE和DELETE.修改记录。视图可以使用户操作方便,而且可以保障数据库系统的安全。

2.创建视图

视图中包含了SELECT查询的结果,因此视图的创建基于SELECT语句和已存在的数据 表,视图可以建立在一张表上,也可以建立在多张表上。

创建视图使用CREATE VIEW语句,基本语法格式如下:

CREATE [OR REPLACE] [[NO]FORCE] VIEW  [schema.] view  [(alias,...)inline_constraint(s)]  [out_of_line_constraint (s)]AS subquery[  WITH{READ ONLY CHECK OPTION[CONSTRAINT constraint]}];

其中,CREATE表示创建新的视图;REPLACE表示替换已经创建的视图;[NO]FORCE表示是否强制创建视图;[schema.]view表示视图所属方案的名称和视图本身的名称;[(alias,…)inline_constraint(s)]表示视图字段的别名和内联的名称 [out _of_line_constraint(s)]表示约束,是与inline constraint(s)相反的声命方式;WITH READ ONLY表示视图为只读;WITH CHECKOPTION表示一旦使用该限制,当对视图增加或修改数据时必须满足子查询的条件。

3.修改视图

修改视图是指修改数据库中存在的视图,当基本表的某些字段发生变化的时候,可以通过修改视图来保持与基本表的一致性。Oracle中通过 CREATE OR REPLACE VIEW语句和ALTER语句来修改视图的约束。

Oracle中如果要修改视图,使用CREATE OR REPLACE VIEW语句,语法如下:

CREATE OR REPLACE [[NO]FORCE] VIEW  [schema.] view  [(alias,...)inline_constraint(s)]      [out_of_line_constraint (s)]AS subquery[  WITH{READ ONLY CHECK OPTION(CONSTRAINT constraint]}];

可以看到,修改视图的语句和创建视图的语句是完全一样的。当视图已经存在时,修改语句对视图进行修改;当视图不存在时,创建视图。

ALTER 语句是 Oracle 提供的另外一种修改视图约束的方法。

4.更新视图

更新视图是指通过视图来插入、更新、删除表中的数据,因为视图是一个虚拟表,其中没有数据。通过视图更新的时候都是转到基本表上进行更新的,如果对视图增加或者删除记录,实际上是对其基本表增加或者删除记录。

UPDATE 视图名 SET 字段1=值1
5.删除视图

当视图不再需要时,可以将其删除,删除一个或多个视图可以使用DROP VIEW语句,语法如下:

DROP VIEW view_name

其中,view_name是要删除的视图名称。删除视图必须拥有DROP权限。

6.限制视图的数据操作

对视图数据的增加或更新实际上是操作视图的源表。通过对视图的限制操作,可以提高数据操安全性。

6.1设置视图只读属性

如果想防止用户修改数据,可以将视图设成只读属性。在CREATE OR REPLACE VIEW语句最后加上WITH READ ONLY。

CREATE OR REPLACE VIEW 视图名 ASSELECT 字段1,字段2,字段n FROM 表WITH READ ONLY;
6.2设置视图的检查属性

在修改视图的数据时,可以指定一定的检查条件。此时需要使用WITH CHECK OPTION来设置视图的检查属性,表示启动了和子查询条件一样的约束。

CREATE OR REPLACE VIEW 视图名 ASSELECT 字段1,字段2,字段n FROM 表WITH CHECK OPTION;
7.Oracle 中视图和表的区别以及联系

视图和表的区别:

①视图是已经编译好的SQL语句,是基于SQL语句的结果集的可视化的表,而表不是。

②视图没有实际的物理记录,而基本表有。

③表是内容,视图是窗口。

④表占用物理空间而视图不占用物理空间,视图只是逻辑概念的存在,表可以及时对 它进行修改,但视图只能用创建的语句来修改。

⑤视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些 SQL语句的集合。从安全的角度来说,视图可以防止用户接触数据表,因而用户不知道表结构。

⑥表属于全局模式的表,是实表;视图属于局部模式的表,是虚表。

⑦视图的建立和删除只影响视图本身,不影响对应的基本表。

视图和表的关系:

视图(View)是在基本表之上建立的表,它的结构(即所定义的列)和内容(即所有记录)都来自基本表,它依据基本表存在而存在。一个视图可以对应一个基本表,也可以对应多个基本表。视图是基本表的抽象和在逻辑意义上建立的新关系。

标签: #oracle创建视图 #oracle视图可以修改数据吗 #oracle查看视图字段类型 #oracle编译视图 #oracle视图的定义