说oracle视图之前,有这样的需求我们先来想一下。 有一张老师信息表,表中字段有:老师id、姓名、婚姻状况、身份证号、代课科目;其中婚姻状况、身份证号教务处人可以查看,但对学生是禁止查看、保密的。此两种身份都用的同一张表,查看不同的结果怎么实现?
说oracle视图之前,有这样的需求我们先来想一下。
有一张老师信息表,表中字段有:老师id、姓名、婚姻状况、身份证号、代课科目;其中婚姻状况、身份证号教务处人可以查看,但对学生是禁止查看、保密的。此两种身份都用的同一张表,查看不同的结果怎么实现? .........这就用到了视图,限制需要保密的字段信息被学生看到。
视图时基于真实表的一个展现。它只是一个逻辑概念,视图中的数据来源于基表(真实表),几乎不占用物理存储空间;视图和普通表一样,可以进行增删改操做;视图保证了数据库数据的安全性。当然还有方便快捷性(如较复杂的sql条件查询可以定义到一个视图中,直接查询该视图) 。先来了解如何定义一个视图:
1、视图完整定义语法:
create[or replace][force][noforce]view view_name
[(column_name)[,….n]]
as
select_statement
[with check option[constraint constraint_name]]
[with read only]
or replace --如视图存在替换存在试图
force][noforce --基表不存在force强行创建; noforce不创建(默认)
with check option[constraint constraint_name] --对视图dml操纵时,是否验证定义视图sql的where条件。
with read only --定义只读视图
2、创建视图、以基表classes为例
sql> select * from classes;
cid cname
--------------------------------------- ----------
1 0901
2 0902
3 0903
为classes表创建默认视图classes_view语句
sql> create or replace noforce view classes_view
2 as
3 select * from classes
4 ;
view created
创建视图成功;上面说到视图和普通表一样,可以进行增删改操作,以新增数据到视图为例说明(修改、删除同新增一样这里不一一列举)
sql> insert into classes_view values(4,1111);
1 row inserted
sql> commit;
commit complete
sql> select * from classes_view;
cid cname
--------------------------------------- ----------
1 0901
2 0902
3 0903
4 1111
同样基表中也存在该条新增数据。
sql> select * from classes;
cid cname
--------------------------------------- ----------
1 0901
2 0902
3 0903
4 1111
为classes表创建带查询条件视图classes_view
sql> create or replace noforce view classes_view
2 as
3 select * from classes where cid
4 ;
view created
sql> select * from classes_view;
cid cname
--------------------------------------- ----------
1 0901
2 0902
--因为创建视图时带where条件cid
sql> select * from classes;
cid cname
--------------------------------------- ----------
1 0901
2 0902
3 0903
4 1111
在classes_view视图新增一条cid为5的信息
sql> insert into classes_view values(5,'2222');
1 row inserted
sql> commit;
commit complete
--视图上添加数据成功。查询视图显示结果:
sql> select * from classes_view;
cid cname
--------------------------------------- ----------
1 0901
2 0902
???怎么没包含我们刚新添加的数据呢?新增数据上哪去了?我们上面说到,操作视图数据实际上操作的是基表,也就是数据保存到了基表classes表中。那么为什么我们定义的视图中查不到了,回看我们视图定义语法:
sql> create or replace noforce view classes_view
2 as
3 select * from classes where cid
4 ;
是因为有where条件限制的,带条件视图不显示没有满足条件的数据,所以也就看不到。那有人就要问了,既然视图只显示满足where条件的信息,那么如何控制不满足视图where条件的信息从视图中录入(insert,update)呢? 使用视图关键字:with check option ,下面讲解with check option如何控制非满足条件如何禁止从视图中录入
--为classes表创建带查询条件且with check option视图classes_view
sql> create or replace noforce view classes_view
2 as
3 select * from classes where cid
4 with check option
5 ;
view created
sql> select * from classes_view;
cid cname
--------------------------------------- ----------
1 0901
2 0902
创建视图成功,视图中只包含约束条件cid
sql> insert into classes_view values(5,2222);
insert into classes_view values(5,2222)
ora-01402: 视图 with check optidn where 子句违规
插入满足where条件数据就能插入成功,如下插入
sql> insert into classes_view values(0,'0001');
1 row inserted
sql> commit;
commit complete
sql> select * from classes_view;
cid cname
--------------------------------------- ----------
0 0001
1 0901
2 0902
修改视图:oracle没有提供修改视图的操纵语句,如想修改视图使用replace关键字
create or replace view classes_view
as
select * from classes
view created
删除视图
sql> drop view classes_view;
view dropped