PLSQL_基础系列5_视图控制WITH CHECK OPTION

2014-12-09 BaoXinjian

一、摘要



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

首先视图只操作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来操作。

1. 对于update, 有with check option,要保证update后,数据要被视图查询出来

2. 对于delete, 有无with check option都一样

3. 对于insert, 有with check option,要保证insert后,数据要被视图查询出来

对于没有where 子句的视图,使用with check option是多余的。

二、案例



Step1. 创建表

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,‘王五‘,‘山東‘);

Step2. 创建带with check option的视图

create view emp_view
as
select * from emp where id=5
with check option;

Step3. 创建没有with check option的视图

create view emp_view2
as
select * from emp where id=‘5‘

Step4. 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行

结论:对于update,有无with选项都是只更改视图出现的記錄,对有whih选项的update,要保证更改后仍可以出现在视图中

Step5. 操作

--update操作
update  emp set id=5 where name=‘張三‘;

--delete操作
delete emp_view where id=‘5‘

--结论:
--对于delete,有无with选项是一样的。
--insert操作
insert into emp_view values (8,‘王‘,‘江蘇‘);--出现 view WITH CHECK OPTION where-clause violation错误
insert into emp_view2 values (8,‘王‘,‘江蘇‘);--执行成功

Step6. 结论:

对于insert,有with选项,插入的数据要最终要可以显示在视图中,对于无with选项的视图可以插入任何不违反约束的记录

Thanks and Regards

参考: http://blog.csdn.net/fredrickhu/article/details/4743204

时间: 2024-11-10 06:55:15

PLSQL_基础系列5_视图控制WITH CHECK OPTION的相关文章

PLSQL_基础系列2_分组函数GROUP BY / ROLLUP / CUBE

2014-11-30 BaoXinjian 一.摘要 ROLLUP 运算符生成的结果集类似于 CUBE 运算符生成的结果集. 1. 下面是 CUBE 和 ROLLUP 之间的具体区别: CUBE 生成的结果集显示了所选列中值的所有组合的聚合. ROLLUP 生成的结果集显示了所选列中值的某一层次结构的聚合. 2. ROLLUP 优点: (1). ROLLUP 返回单个结果集,而 COMPUTE BY 返回多个结果集,而多个结果集会增加应用程序代码的复杂性. (2). ROLLUP 可以在服务器游

PLSQL_基础系列4_时间间隔INTERVAL

2014-12-08 BaoXinjian 一.摘要 INTERVAL数据类型用来存储两个时间戳之间的时间间隔. 可以指定years and months,或者days,hours,minuts,seconds之间的间隔. ORACLE支持两种INTEVAL类型,它们分别是YEAR TO MONTH和DAY TO SECOND. 每个类型都包含leading field和trailing field.主参数定义要被计算的date或者time,副参数定义最小增长量 二.语法 1. Oracle语法

PLSQL_基础系列3_合并操作UNION / UNION ALL / MINUS / INTERSET

2014-11-30 BaoXinjian 一.摘要 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到Union或者Union All关键字.Union(或称为联合)的作用是将多个结果合并在一起显示出来. Union和Union All的区别是,Union会自动压缩多个结果集合中的重复结果,而Union All则将所有的结果全部显示出来,不管是不是重复. Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序: Union All:对两个结果集进行

PLSQL_基础系列1_正则表达式regexp_like/substr/instr/replace

2014-11-30 BaoXinjian 一.摘要 ORACLE中的支持正则表达式的函数主要有下面四个: 1 REGEXP_LIKE :与LIKE的功能相似 2 REGEXP_INSTR :与INSTR的功能相似 3 REGEXP_SUBSTR :与SUBSTR的功能相似 4 REGEXP_REPLACE :与REPLACE的功能相似 它们在用法上与Oracle SQL 函数LIKE.INSTR.SUBSTR 和REPLACE 用法相同. 二.调用格式 1. 格式: REGEXP_INSTR

Java零基础系列005——条件控制

public class Control { public static void main(String[] args) { //java里常用的条件控制语句有if-esle,switch语句. boolean tr = true; boolean fa = false; //if语句后面的括号里装的是逻辑,其结果是boolean类型,当括号中结果为true时,程序运行大括号里的语句,否者运行else里面的. System.out.println("*******************if-

PLSQL_基础系列9_时间戳Timestamp

2013-11-09 BaoXinjian 1. 获取系统时间的语句(ssxff6获取小数点后面六位) select sysdate,systimestamp,to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6'), to_char(systimestamp, 'yyyymmdd hh24:mi:ss.ff6') from dual; 2. 字符型转成timestamp select to_timestamp('2011-09-14 12:52:42.1

PLSQL_基础系列1_正则表达REGEXP_LIKE / SUBSTR / INSTR / REPLACE

2014-11-30 BaoXinjian 一.摘要 ORACLE中的支持正则表达式的函数主要有下面四个: 1 REGEXP_LIKE :与LIKE的功能相似 2 REGEXP_INSTR :与INSTR的功能相似 3 REGEXP_SUBSTR :与SUBSTR的功能相似 4 REGEXP_REPLACE :与REPLACE的功能相似 它们在用法上与Oracle SQL 函数LIKE.INSTR.SUBSTR 和REPLACE 用法相同. 二.调用格式 1. 格式: REGEXP_INSTR

PLSQL_基础系列8_操作符标LPAD / TRUNC / DECODE / TRIM / INSTR

2014-12-09 BaoXinjian 一.字符函数 1. LOWER (strexp) - 返回字符串,并将所有的字符小写. select lower('ABCDE') from dual 2. UPPER (strexp)     返回字符串,并将所有的字符大写. select upper('abcdf') from dual 3.INITCAP(strexp)    将字符串的(每个单词的)第一个字母变为大写,后面的小写; select initcap(' source fore')

PLSQL_基础系列7_插入方式Pivoting / Unconditional / Conditional ALL / Conditional FIRST INSERT

2014-12-08 BaoXinjian 一.摘要 Oracle Insert的多种方式 1. standard insert 1. pivoting Insert 2. unconditional insert 3. conditional all insert / conditional first insert 二.标准Insert - 单表单行插入 标准Insert -- 单表单行插入 1. 语法: INSERT INTO table [(column1,column2,...)] V