WITH CHECK OPTION
通过有with check option选项的视图操作基表(只是面对单表,对连接多表的视图正在寻找答案),有以下结论:
- 首先视图只操作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来操作。
- 对于update,有with check option,要保证update后,数据要被视图查询出来
- 对于delete,有无with check option都一样
- 对于insert,有with check option,要保证insert后,数据要被视图查询出来
- 对于没有where 子句的视图,使用with check option是多余的。
以例子验证结论:
创建表
create table emp(
id number(5,0),
name varchar2(12),
address varchar2(12)
);
insert into emp values (5,'张三','广西);
insert into emp values (6,'李四','北京');
insert into emp values (7,'王五','山东');
创建带with check option的视图
create view emp_view
as
select * from emp where id=5
with check option;
创建没有with check option的视图
create view emp_view2
as
select * from emp where id=5
update操作
update emp_view
set name='陈六'
where id=6;
虽然基表有id=6
的记录,但emp_view
无法查看到,所以这个修改不会影响基表内容
update emp_view set id=6 where id=5;
出现view WITH CHECK OPTION where-clause violation
错误
update emp_view2 set id=6 where id=5;
成功执行plain行
结论1:
- 对于update,有无with选项都是只更改视图出现的记录,对有with选项的update,要保证更改后仍可以出现在视图中
- 把数据改回原型
update emp set id=5 where name='张三';
- delete操作
delete emp_view where id=5
结论2:
对于delete,有无with选项是一样的。
- insert操作
insert into emp_view values (8,'王','江苏);
出现view WITH CHECK OPTION where-clause violation
错误
insert into emp_view2 values (8,'王','江苏');
执行成功
结论3:
对于insert,有with选项,插入的数据要最终要可以显示在视图中,对于无with选项的视图可以插入任何不违反约束的记录。