WITH CHECK OPTION的用法
1. INSERT
INSERT INTO(<SELECT CLAUSE> WITH CHECK OPTION) VALUES(...)
for example:
CREATE TABLE sharon_test(ID NUMBER, NAME VARCHAR2(20), TYPE VARCHAR2(20)); INSERT INTO(SELECT ID, NAME, TYPE FROM sharon_test WHERE ID < 10 WITH CHECK OPTION) VALUES(9, 'test', 'test');
这种语法看起来很特殊,实际上是insert进subquery中的这张表里,只不过如果不满足subquery中的where条件的话,就不允许插入。同样,where条件指定的列如果
不在insert的列中,也不允许插入。如果不加WITH CHECK OPTION的话,则不作检查。需要注意的是,subquery实际上不会被执行。例如:
(1) 无WITH CHECK OPTION
SQL> insert into(select id, name, type from sharon_test where id < 10) values(11, 'test', 'test');--
1 row inserted
(2) 有WITH CHECK OPTION,且不满足where条件
SQL> insert into(select id, name, type from sharon_test where id < 10 with check option) values(11, 'test', 'test');
insert into(select id, name, type from sharon_test where id < 10 with check option) values(11, 'test', 'test')
ORA-01402: view WITH CHECK OPTION where-clause violation
(3) where条件列不在插入列中
SQL> insert into(select name, type from sharon_test where id < 10 with check option) values('test', 'test');
insert into(select name, type from sharon_test where id < 10 with check option) values('test', 'test')
ORA-01402: view WITH CHECK OPTION where-clause violation
2. VIEW
创建一个视图:
CREATE VIEW test_view AS SELECT ID, NAME FROM sharon_test WHERE TYPE = 'test' WITH CHECK OPTION; INSERT INTO test_view VALUES(12, 'dev');
执行insert语句时,同样会报ORA-01402: view WITH CHECK OPTION where-clause violation 这个error,去掉WITH CHECK OPTION的话则可以。WITH CHECK OPTION可以这么解释:通过视图进行的修改,必须也能通过该视图看到修改后的结果。比如insert,那么加的这条记录在刷新视图后必须可以看到;update,修改完的结果也必须能通过该视图看到;delete,则只能删除该视图中显示的记录。因此,使用WITH CHECK OPTION,必须考虑到不让它在修改完后从视图中消失。任何导致记录消失的修改都会被取消,并显示错误信息。
posted on 2012-04-23 11:10 时间给了够幸福的结局 阅读(1866) 评论(0) 编辑 收藏 举报