视图是在数据表基础上定义的一个虚拟表,在打开视图是从数据表提取查询结果
一个视图是从特定的角度查看数据库的方式、
限定不同用户能看到的数据库的范围
维护数据安全的一种方式
视图可以修改数据库里的数据
视图中只负责存储select命令,不保存数据,不占据物理物理空间
创建视图
create view <视图名>[(<列名>[,<列名>]…)] as <子查询>[WITH CHECK OPTION];
--视图查询时,是聚集函数或列表达式,即查询出的列没有名字是,必须指定列名
--视图可以当做基本表来使用,可以在视图上创建新的视图、视图查询或视图更新操作
视图的撤销
drop view <视图名>
视图的更新
通过视图来插图、删除和修改数据
为防止用户通过视图进行更新数据,有意或无意对不属于视图范围内的基本表数据进行操作,可在定义视图时加上[with check option]子句
在视图上更新数据是,DBMS检查视图定义中的条件,若不满足条件,则拒绝执行更新操作
insert into 视图名 values
update 视图名 set
delete from 视图名
一般DBS只允许对单源表视图进行更新操作
单源表视图是指从单个基本表导出、保留了关键字的视图
在关系数据库的三极模式结构中
表的结构定义属于概念模式
索引的结构定义、存储定义属于内模式
视图的定义属于外模式