视图是指计算机数据库中的视图,是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和
列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。
视图含义
从用户角度来看,一个视图是从一个特定的角度来查看数据库中的数据。从数据库系统内部来看,一个视图是由SELECT语句组成的查询定义的虚拟表。从
数据库系统内部来看,视图是由一张或多张表中的数据组成的,从数据库系统外部来看,视图就如同一张表一样。
视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图的作用类似于筛选。定义视图的筛选可以来自当前或其它数据库的一个或多个表,或者其它视图。
分布式查询也可用于定义使用多个异类源数据的视图。
视图是存储在数据库中的查询的SQL 语句,它主要出于两种原因:安全原因, 视图可以隐藏一些数据,如:
社会保险基金表,可以用视图只显示姓名,地址,而不显示
社会保险号和工资数等,另一原因是可使复杂的查询易于理解和使用。
视图:查看图形或文档的方式。
视图一经定义便存储在数据库中,与其相对应的数据并没有像表那样又在数据库中再存储一份,通过视图看到的数据只是存放在基本表中的数据。对视图的操作与
对表的操作一样,可以对其进行查询、修改(有一定的限制)、删除。
当对通过视图看到的数据进行修改时,相应的基本表的数据也要发生变化,同时,若基本表的数据发生变化,则这种变化也可以自动地反映到视图中。
种类区别
关系视图:
Oracle视图是作为
数据库对象存在的,因此,创建之后也可以通过工具或
数据字典来查看视图的相关信息。这是大家常用的视图,如:create view 视图。
内嵌视图:在from语句中的可以把表改成一个
子查询,如:select a.id ,b.id from emp a,(select id from dept) b where a.id=b.id内嵌视图不属于任何用户,也不是对象,内嵌视图是子查询的一种,可以与
数据表、视图一样作为查询语句的
数据源存在,但在形式上有较大的区别,内嵌视图不必使用create view命令进行创建,因此,在数据字典中也无法获得相应信息。内嵌视图的特点在于无须创建真正的数据库对象,而只是封装查询,因此会节约数据库资源,同时不会增加维护成本。但是内嵌视图不具有
可复用性,因此当预期将在多处调用到同一查询定义时,还是应该使用关系视图。
对象视图:对象类型在
数据库编程中有许多好处,但有时,
应用程序已经开发完成。为了迎合对象类型而重建数据表是不现实的。对象视图正是解决这一问题的优秀策略。
对象视图创建之后,同样可以在数据字典中获得其相应信息。利用
Oracle内置视图user_views可以获得对象视图相关信息。Oracle中的对象数据实际仍然以关系数据的形式存储。但是,对象的特性,例如继承、封装等,都为开发人员提供了更加灵活的处理形式。同样,可以构造复杂的对象类型来封装复杂的多表查询。
物化视图:常用于数据库的
容灾,不是传统意义上虚拟视图,是实体化视图,和表一样可以
存储数据、查询数据。主备数据库
数据同步通过物化视图实现,主备数据库通过data link连接,在主备数据库物化视图进行数据复制。当
主数据库垮掉时,备数据库接管,实现容灾。
视图作用
* 简单性。看到的就是需要的。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。
* 安全性。通过视图用户只能查询和修改他们所能见到的数据。但不能授权到数据库特定行和特定的列上。通过视图,用户可以被限制在数据的不同子集上:
使用权限可被限制在另一视图的一个子集上,或是一些视图和
基表合并后的子集上。
* 逻辑数据独立性。视图可帮助用户屏蔽真实表结构变化带来的影响。
软道语录
视图:
视图是由一个或者多个表组成的虚拟表。
视图优点
视图有很多优点,主要表现在:
·视点集中
·简化操作
·定制数据
·合并分割数据
·安全性
1. 视点集中
视图集中即是使用户只关心它感兴趣的某些特定数据和他们所负责的特定任务。这样通过只允许用户看到视图中所定义的数据而不是视图引用表中的数据而提高了数据的安全性。
2. 简化操作
视图大大简化了用户对数据的操作。因为在定义视图时,若视图本身就是一个复杂查询的
结果集,这样在每一次执行相同的查询时,不必重新写这些复杂的查询语句,只要一条简单的查询视图语句即可。可见视图向用户隐藏了表与表之间的复杂的连接操作。
3. 定制数据
视图能够实现让不同的用户以不同的方式看到不同或相同的
数据集。因此,当有许多不同水平的用户共用同一数据库时,这显得极为重要。
4. 合并分割数据
在有些情况下,由于表中数据量太大,故在表的设计时常将表进行
水平分割或垂直分割,但表的结构的变化却对
应用程序产生不良的影响。如果使用视图就可以重新保持原有的
结构关系,从而使
外模式保持不变,原有的应用程序仍可以通过视图来重载数据。
5. 安全性
视图可以作为一种安全机制。通过视图用户只能查看和修改他们所能看到的数据。其它数据库或表既不可见也不可以访问。如果某一用户想要访问视图的
结果集,必须授予其
访问权限。视图所引用表的访问权限与视图权限的设置互不影响。
视图的安全性
视图的安全性可以防止未
授权用户查看特定的行或列,使用户只能看到表中特定行的方法如下:
2 建立视图,是用户只能看到标有自己用户名的行;
3 把视图授权给其他用户。
视图可以使应用程序和数据库表在一定程度上独立。如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。视图可以在以下几个方面使程序与数据独立:
1 如果应用建立在数据库表上,当数据库表发生变化时,可以在表上建立视图,通过视图屏蔽表的变化,从而应用程序可以不动。
2 如果应用建立在数据库表上,当应用发生变化时,可以在表上建立视图,通过视图屏蔽应用的变化,从而使数据库表不动。
3 如果应用建立在视图上,当数据库表发生变化时,可以在表上修改视图,通过视图屏蔽表的变化,从而应用程序可以不动。
4 如果应用建立在视图上,当应用发生变化时,可以在表上修改视图,通过视图屏蔽应用的变化,从而数据库可以不动。
书写格式
CREATE VIEW <视图名>[(列名组)]AS <子查询>
DROP VIEW <视图名>
注意:视图可以和基本表一样被查询,但是利用视图进行数据增,删,改操作,会受到一定的限制。
(1)由两个以上的基本表导出的视图(2)视图的字段来自字段
表达式函数(3)视图定义中有
嵌套查询(4)在一个不允许更新的视图上定义的视图
创建管理
(创建视图时注意事项的介绍)
1.使用企业管理器创建视图: 2.使用企业管理器的“向导”创建视图: 3.使用企业管理器的修改视图: 注意:在 “
设计视图”时完成的工作: 添加表/删除表添加引用字段/删除引用字段调整字段顺序设置分组 设置过滤条件设置引用字段是否输出设置视图其他属性4.使用企业管理器的删除视图:
(二). 用T-SQL语句创建与管理视图
(查看由
企业管理器创建的视图—“
项目信息”其相应的T-SQL语句)(“视图属性”) 1. 使用CREATE VIEW创建视图的语法:参见教材p130~135 例子1:选择‘员工表’和‘项目表’中的部分字段和记录创建视图,并且限制表‘员工表’ 中的记录只能是部门为“
项目部”的记录集合,视图定义为view_part,其程序清单如下:
CREATE VIEW view_partAS SELECT 员工表.编号,员工表.姓名,员工表.性别,员工表.所属部门,项目表.
项目编号,项目表.名称FROM 项目表
INNER JOIN 员工表 ON 项目表.负责人 = 员工表.编号WHERE 员工表.所属部门='项目部'
例子2:定义视图时指定别名并加密
CREATE VIEW 项目信息视图 ,项目名称,项目客户,项目负责人,DATEDIFF,day,项目表.
开始日期,项目表.结束日期,FROM 项目表, INNER JOIN 员工表 ,ON 项目表负责人 , 员工表.编号 INNER JOIN ,客户表 ,ON 项目表 ,客户 = 客户表.客户编号 WHERE , 员工表.所属部门='项目部'
使用语句:execsp_helptext‘项目信息视图’显示消息为:“对象备注已加密。”
应用举例
例子5-3:使用WITH CHECK OPTION子句问题提出:若创建视图ygb_view,其程序清单如下:
CREATE VIEW ygb_view AS SELECT * FROM 员工表 WHERE 员工表.性别=‘女’执行下列语句,插入
新记录:INSERT INTO ygb_view(姓名,性别,工资)values(‘李立三’,‘男’,2300)
插入操作成功,但不合理。解决办法:使用with check option,程序清单如下:
CREATE VIEW ygb_view AS SELECT * FROM 员工表 WHERE 员工表.性别=‘女’With check option
同样,插入新记录:INSERT INTO ygb_view(姓名,性别,工资) values(‘李立三’,‘男’,2300)插入操作将失败!
2.使用ALTER VIEW修改视图 语法:参见教材3.删除视图DROP VIEW 使用DROP VIEW命令删除视图的语法如下:DROP VIEW 视图名1 [,……]例: DROP VIEW ygb_view
(一)、通过视图添加表数据
使用INSERT语句实现。 注意:视图是虚拟表,其本身不
存储数据(来自其引用表),添加的数据是存储于视图参照的
数据表中。
条件分析:(1)用户有向数据表插入数据的权限;(2)视图只引用表中部分字段,插入数据时只能是明确其应用的字段取值;(3)未引用的字段应具备下列条件之一: 允许
空值;设有
默认值;是标识字段;
数据类型是timestamp或uniqueidentifer;(4)视图不能包含多个字段的组合;(5)视图不能包含使用统计函数的结果;(6)视图不能包含
DISTINCT或
GROUP BY子句;(7)定义视图使用WITH CHECK OPTION,则插入数据应符合相应条件;(8)若视图引用多个表,一条INSERT语句只能同一个
基表表
中数据;
例:首先创建了一个新的视图:
CREATE VIEW ygb_view AS SELECT * FROM 员工表 WHERE 员工表.性别=‘女’ with check option
然后,通过执行以下语句使用该视图向基表添加一条新的
数据记录:INSERT INTO ygb_view(姓名,性别,工资) values(‘李立平’,‘女’,2300)
(二)、更新数据记录 使用视图可以更新基表数据记录(注意使用INSERT时的限制同样适用)。例子3:(1) update 项目_view set 项目负责人= ‘王大力’
where 项目负责人= ‘王立兵’(2) update 项目_view set 结束日期= DATEADD(day,50,结束日期) where 客户名称=‘CCH公司’
(三)、删除数据记录 利用
DELETE语句,使用视图删除记录,可以删除任何基表中的记录。 注意: 必须指定在视图中定义过的字段来删除记录; 视图引用多个表时,无法用DELETE命令删除数据。例子4:delete ygb_view where 员工工资<1500