什么是视图
视图就是一种数据查询机制,不同于数据表,视图并不涉及数据存储,不用担心视图会填满你的磁盘空间。可以先通过命名select语句来创建视图,然后将该查询保存起来供他人使用。其他用户使用视图访问数据时就像自己直接查询数据表一样(实际上,他们甚至可能不知道正在使用视图)
为什么要使用视图
数据安全
如果你创建了数据表并允许用户查询,用户就可以访问数据表中的每一行和每一列。之前曾指出,数据表中的某些列可能包含敏感数据。应对这种情况的最好方法就是保持数据表的私有性(不授权任何用户select许可),然后创建一个或多个视图,忽略或模糊化敏感列。也可以通过在视图定义中添加where子句来约束用户可以访问的行。
Oracle Database用户还有另一种选择可以保护数据表的行列数据安全:虚拟私有数据库(virtual private database,VPD)。VPD允许用户对数据表施加策略,服务器据此对用户的查询进行修改。例如,你可以要求销售部和市场部的人员只能够看到活跃客户,那么条件active = 1会被添加到所有针对customer数据表的查询中
数据聚合
生成报表的应用程序通常需要聚合数据,视图就是一种不错的方法,可以使数据就像预先聚合并存储在数据库中一样。
隐藏复杂性
部署视图的一个最常见的原因是为了使最终用户免受复杂性的影响。
连接分区数据
一些数据库设计人员为了提升性能会将较大的数据表拆分为多个部分。假设payment数据表变大了,设计人员可能会决定将其拆分为两个数据表:payment_current和payment_historic。前者保存最近6个月数据,后者保存6个月之前的所有数据,如果想要查看特定客户的所有支付数据,需要查询两个数据表,通过创建视图,查询两个数据表并合并查询结果,就可以让所有的支付数据看起来就像存储在单个数据表中一样