当前位置: 首页 > 图文教程 > 数据库 > Oracle > Oracle认证:向视图中插入数据的方法

Oracle
Excel VBA连接并操作Oracle
Oracle 外连接实现代码
oracle 存储过程和函数例子
Oracle 数据库操作类
ORACLE 分区表的设计
Oracle 用户权限管理方法
Oracle In和exists not in和not exists的比较分析
利用windows任务计划实现oracle的定期备份
ORACLE11g随RHEL5系统自动启动与关闭的设置方法
在oracle 数据库查询的select 查询字段中关联其他表的方法
plsql和tsql常用函数比对
plsql与tsql的语法不同
ASP.NET调用oracle存储过程实现快速分页
执行drop表操作后数据库无法起动
分析Oracle有时会用索引来查找数据的原因
数据从MySQL迁移到 Oracle的注意事项
快速理解Oracle归档模式的命令及参数
在Oracle里加快SQL执行的三种方法
几条常见的数据库分页 SQL 语句
Oracle9I OCP认证过程

Oracle认证:向视图中插入数据的方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 120 ::
收藏到网摘: n/a

  插入视图的条件:

  1.如果视图是基于一个基础表产生的,那么这就称为非连接视图,所有的非连接视图都是可以更新的,也就是说可以在该视图上进行,INSERT,UPDATE,DELETE的操作.

  2.如果是连接视图,那就要遵守基本更新准则了.现在我只对INSERT准则做一下说明:在INSERT语句中不能显式或隐式的引用到任何非码保留基础表中的字段,如果在定义视图中使用了WITH CHECK OPTION子句,那就不能对视图执行INSERT操作.

  注:码保留表,非码保留表的解释:

  在DEPT中,DEPT_NO是主码,EMP中,EMP_NO是主码

  然后建立连接视图:

  create view emp_dept as

  select emp.emp_no,emp.emp_name,emp.dept_no,dept.name

  from emp,dept

  where emp.dept_no=dept.dept_no

  这个视图中,EMP_NO仍然充当主码,所以EMP为码保留表,而DEPT中的DEPT_NO就不是主码了,所以为非码保留表.

  多张表关联后需要向视图插入数据,建议使用替代触发器

  create trigger [触发器名]

  on [视图名]

  instead of insert

  as

  begin

  --声明变量;

  --从inserted表中查出所有列的数据,分别赋给声明好的变量;

  --用上面的数据向第一张表插入数据

  --用上面的数据向第二张表插入数据

  end

  此外通过user_updatable_columns表能够查询到该表或者视图是否可更新。