视图(view),也称虚表, 不占用物理空间,这个也是相对概念,因为视图本身的定义语句还是要存储在数据字典里的。视图只有逻辑定义。每次使用的时候,只是重新执行SQL。
优点
1、可以限制用户只能通过视图检索数据。这样就可以对最终用户屏蔽建表时底层的基表。
2、可以将复杂的查询保存为视图。可以对最终用户屏蔽一定的复杂性。
3、限制某个视图只能访问基表中的部分列或者部分行的特定数据。这样可以实现一定的安全性。
4、从多张基表中按一定的业务逻辑抽出用户关心的部分,形成一张虚拟表。
1、需要权限:
a) 用户必须具有create view系统权限;
b) 要在其他方案中创建视图,用户必须具有create any view系统权限
2、语法:
3、参数说明
a) OR REPLACE:如果视图已经存在,则替换旧视图。
b) FORCE:即使基表不存在,也可以创建该视图,但是该视图不能正常使用,当基表创建成功后,视图才能正常使用。
c) NOFORCE:如果基表不存在,无法创建视图,该项是默认选项。
d) WITH READ ONLY:默认可以通过视图对基表执行增删改操作,但是有很多在基表上的限制(比如:基表中某列不能为空,但是该列没有出现在视图中,则不能通过视图执行insert操作),WITH READ ONLY说明视图是只读视图,不能通过该视图进行增删改操作。现实开发中,基本上不通过视图对表中的数据进行增删改操作。
1、了解更新原理
第一步:将针对视图的SQL语句与视图的定义语句(保存在数据字典中)“合并”成一条SQL语句
第二步:在内存结构的共享SQL区中“解析”(并优化)合并后的SQL语
第三步:“执行”SQL语句
2、查询视图“可更新”(包括“增删改”)的列
a) dba_updatable_columns——显示数据库所有视图中的所有列的可更新状态
b) all_updatable_columns——显示用户可访问的视图中的所有列的可更新状态
c) user_updatable_columns——显示用户拥有的视图中的所有列的可更新状态
使用数据字典视图
1、dba_views——DBA视图描述数据库中的所有视图
2、all_views——ALL视图描述用户“可访问的”视图
3、user_views——USER视图描述“用户拥有的”视图
4、dba_tab_columns——DBA视图描述数据库中的所有视图的列(或表的列)
5、all_tab_columns——ALL视图描述用户“可访问的”视图的列(或表的列)
6、user_tab_columns——USER视图描述“用户拥有的”视图的列(或表的列)