在Oracle中向视图中插入数据的方法

下雪了,先是小朵小朵的雪花,柳絮般轻轻地飘扬;然后越下越大,一阵紧似一阵。
插入视图的条件:
1.如果视图是基于一个基础表产生的,那么这就称为非连接视图,所有的非连接视图都是可以更新的,也就是说可以在该视图上进行,INSERT,UPDATE,DELETE的操作.
2.如果是连接视图,那就要遵守基本更新准则了.现在我只对INSERT准则做一下说明:在INSERT语句中不能显式或隐式的引用到任何非码保留基础表中的字段,如果在定义视图中使用了WITHCHECKOPTION子句,那就不能对视图执行INSERT操作.
注:码保留表,非码保留表的解释:
在DEPT中,DEPT_NO是主码,EMP中,EMP_NO是主码
然后建立连接视图:
createviewemp_deptas
selectemp.emp_no,emp.emp_name,emp.dept_no,dept.name
fromemp,dept
whereemp.dept_no=dept.dept_no 这个视图中,EMP_NO仍然充当主码,所以EMP为码保留表,而DEPT中的DEPT_NO就不是主码了,所以为非码保留表. 多张表关联后需要向视图插入数据,建议使用替代触发器 createtrigger[触发器名]
on[视图名]
insteadofinsert
as
begin
--声明变量;
--从inserted表中查出所有列的数据,分别赋给声明好的变量; --用上面的数据向第一张表插入数据
--用上面的数据向第二张表插入数据
end 此外通过user_updatable_columns表能够查询到该表或者视图是否可更新。

本文在Oracle中向视图中插入数据的方法到此结束。只要努力,你就能成为你想成为的人。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
Oracle缩表空间的完整如何解决实例

详解Oracle控制文件及日志文件的管理问题

oracle指定类型和指定位数创建序列号的代码详解

Oracle官方工具SQLDeveloper的简单如何使用

Oracle中锁(lock)的用法