【SQL】视图WITH CHECK OPTION

WITH CHECK OPTION

通过有with check option选项的视图操作基表(只是面对单表,对连接多表的视图正在寻找答案),有以下结论:

  • 首先视图只操作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来操作。
  1. 对于update,有with check option,要保证update后,数据要被视图查询出来
  2. 对于delete,有无with check option都一样
  3. 对于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选项的视图可以插入任何不违反约束的记录。

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cout0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值