Oracle-31-对视图DML操作

一、对视图进行DML操作

1.创建一个视图v_person

create or replace noforceview v_person

as select *from person
where id between 1003 and 1007;

2.向视图v_person中进行insert操作

insertinto
v_person (id,name) values(1010,’J’)

【注意】对视图进行DML操作时候。仅仅能对简单视图运行DML操作。复杂视图不支持DML操作。因为v_person没有使用with
check option。因此对于子查询检索到的行能够进行增删改查。

例1:练习对视图(没有with check option)插入数据。

解:当前用户下视图v_stu的数据

视图v_stu的基表是student表,该表当前的数据:

对视图插入新数据:

查询视图发现多了一行:

查询基表发现多了一行:

因此。对视图进行DML操作可达到改动基表数据的效果。

例2:练习对视图(有with check option)插入数据。

解:创建视图并将已存在的视图覆盖。带上with check option:

然后插入例如以下数据:

报错原因是’男’不满足视图中的where条件。视图有with check option是对新数据进行校验。假设满足where条件,则同意插入,否则不同意。

同理,例如以下报错是由于视图在创建的时候要求仅仅读。即with read only:

例3:练习两张基表生成视图且验证是否能在该视图中插入新数据。

解:当前的sc表:

当前的course表:

基于sc表和course表创建视图v_2,注意下图SQL命令:

向视图中插入新数据:

报错原因是该视图是基于两张表创建的。所以无法插入新数据。

【注意】

下面三种情况无法对视图做DML操作:

1.带有with check option的视图,假设插入数据不满足where条件则无法做DML操作。如例2

2.带有with read only的视图。例2

3.基于两张及两张以上基表的视图,比方student,course,sc表生成一个视图,那么这个视图无法做DML操作如例3

时间: 2024-12-29 23:02:46

Oracle-31-对视图DML操作的相关文章

Oracle锁2:DML操作和锁

Oracle为DML操作自动获取行锁和表锁,操作的类型决定了锁的行为,下面对DML操作锁的情况作了一个汇总: SQL Statement Row Locks Table Lock Mode RS RX S SRX X SELECT ... FROM table... -- none Y Y Y Y Y INSERT INTO table ... Yes SX Y Y N N N UPDATE table ... Yes SX Y(注) Y(注) N N N MERGE INTO table ..

flashback之——挖掘SCN(DDL和DML操作示例)

------------------------------------------------------------------------------------------- 1.查询当前日志组21:43:00 [email protected]>select * from v$log;          1    1    36   52428800   512     1 NO  CURRENT     1349824 2.查询日志文件 21:42:44 [email protect

允许进行DML操作的视图条件

视图可以屏蔽某些基表的信息,或是join多个基表组成一个复杂查询,视图本身也是可以进行DML操作,但受一些条件的限制. 首先我们看下官方文档对视图进行DML操作的要求说明: The following notes apply to updatable views: An updatable view is one you can use to insert, update, or delete base table rows. You can create a view to be inhere

Oracle的闪回技术--闪回错误的DML操作

提交DML操作后,该操作使用的还原段就可以被其它对象使用了,为了保证闪回操作时这些数据仍然被保存在还原段中,可能需要重新设置undo_retention参数,表示一个事务提交后,该事务的数据必须保存在还原段中的时间:但是这也并不能完全保证指定的时间的数据一定能够被恢复,还原表空间没有足够的时间时,仍会覆盖要求保留的磁盘空间. 查看undo_retention的当前值: SQL> show parameter undo_retention NAME TYPE VALUE -------------

Oracle ddl 和 dml 操作

  ddl 操作 窗口设置用户权限的方法  Oracle的数据类型  按住Ctrl点击表名 ,可以鼠标操作  插入的数据需要满足创建表的检查  主表clazz删除数据从表设置级联也会一同删除 有约束也强制删除 Oracle dml操作  简化分页查询 创建百万条记录的表 Oracle 数据库的备份 导入导出 原文地址:https://www.cnblogs.com/qingyundian/p/9142659.html

Oracle中 “ORA-14551: 无法在查询中执行 DML 操作” 如何解决

在编写一个数据库函数时,方法实现需要查询后进行修改,出现ora-14551的错误 create or replace function fun_DxcBillSn(tabType integer,tabName varchar2,fieldStr varchar2)return integer is serialSn integer; maxVal integer; nowMonth varchar(20); begin --获取当前时间的月份-- select to_char(Sysdate,

Oracle 10g 物理Dataguard日常操作维护(二)

3.3进程日志的监控操作 3.3.1 查看备库进程状态 SQL>select process,client_process,sequence#,status from v$managed_standby PROCESS   CLIENT_P  SEQUENCE#    STATUS ---------       --------     ---------- -      ----------- ARCH      ARCH            153       CLOSING ARCH 

使用Trigger审计一张表的DML操作

最近ogg的灾备端复制进程中的一张表老是报错ORA-04031,但是又查不到原因,于是想用审计的方法来看到底这张表是被谁做了DML操作,把数据搞没了.本来想用数据库自带的审计功能参考:http://hbxztc.blog.51cto.com/1587495/1870181 但是需要重启数据库,就放弃了,上网查资料看到有人用触发器来实现这个功能,于是自己也做了尝试. 平台11.2.0.4 [email protected]>select * from v$version; BANNER -----

【转】Oracle之物化视图

原文地址:http://www.cnblogs.com/Ronger/archive/2012/03/28/2420962.html 物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的.普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询.这样对整体查询性能的提高,并没有实质上的好处.1.物化视图的类型:ON DEMAND.ON COMMIT 二者的区别在于刷新方法的不同,ON DEMAND顾名思义,仅在该物化视