SQL学习指南——视图

什么是视图

视图就是一种数据查询机制,不同于数据表,视图并不涉及数据存储,不用担心视图会填满你的磁盘空间。可以先通过命名select语句来创建视图,然后将该查询保存起来供他人使用。其他用户使用视图访问数据时就像自己直接查询数据表一样(实际上,他们甚至可能不知道正在使用视图)

为什么要使用视图

数据安全

如果你创建了数据表并允许用户查询,用户就可以访问数据表中的每一行和每一列。之前曾指出,数据表中的某些列可能包含敏感数据。应对这种情况的最好方法就是保持数据表的私有性(不授权任何用户select许可),然后创建一个或多个视图,忽略或模糊化敏感列。也可以通过在视图定义中添加where子句来约束用户可以访问的行。

Oracle Database用户还有另一种选择可以保护数据表的行列数据安全:虚拟私有数据库(virtual private database,VPD)。VPD允许用户对数据表施加策略,服务器据此对用户的查询进行修改。例如,你可以要求销售部和市场部的人员只能够看到活跃客户,那么条件active = 1会被添加到所有针对customer数据表的查询中

数据聚合

生成报表的应用程序通常需要聚合数据,视图就是一种不错的方法,可以使数据就像预先聚合并存储在数据库中一样。

隐藏复杂性

部署视图的一个最常见的原因是为了使最终用户免受复杂性的影响。

连接分区数据

一些数据库设计人员为了提升性能会将较大的数据表拆分为多个部分。假设payment数据表变大了,设计人员可能会决定将其拆分为两个数据表:payment_current和payment_historic。前者保存最近6个月数据,后者保存6个月之前的所有数据,如果想要查看特定客户的所有支付数据,需要查询两个数据表,通过创建视图,查询两个数据表并合并查询结果,就可以让所有的支付数据看起来就像存储在单个数据表中一样

相关推荐
活宝小娜2 小时前
mysql详细安装教程
数据库·mysql·adb
贤时间2 小时前
codex 助力oracle ebs 开发
数据库·oracle
秉承初心2 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle
2601_962072552 小时前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
Database_Cool_2 小时前
即席查询(Ad-Hoc)数据库选型:AnalyticDB MySQL 秒级 Ad-Hoc 分析方案
数据库·mysql
Nontee3 小时前
新手数据库进阶:一条UPDATE语句的“奇妙漂流”
数据库
赵渝强老师3 小时前
【赵渝强老师】openGauss的数据库
数据库·opengauss·国产数据库·高斯数据库
HackTwoHub3 小时前
Sqli-Scanner SQL注入SKILL自动化挖掘SQL注入,零依赖自动化SQL注入挖掘,赏金猎人
数据库·人工智能·sql·web安全·网络安全·自动化·系统安全