首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从零开始学习Oracle之视图

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

1.视图概述

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

2.创建视图

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

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

其中,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语句,语法如下:

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

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

4.更新视图

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

5.删除视图

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

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

6.限制视图的数据操作

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

6.1设置视图只读属性

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

6.2设置视图的检查属性

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

7.Oracle 中视图和表的区别以及联系

视图和表的区别:

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

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

表是内容,视图是窗口。

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

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

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

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

视图和表的关系:

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

  • 发表于:
  • 原文链接https://page.om.qq.com/page/OFn6c-tLnwhDGfzhO_rgP_ZA0
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券
http://www.vxiaotou.com