Oracle数据库中向视图中插入数据_Oracle数据库_黑客防线网安服务器维护基地--Powered by WWW.RONGSEN.COM.CN

Oracle中向视图中插入数据

作者:黑客防线网安Oracle维护基地 来源:黑客防线网安Oracle维护基地 浏览次数:0

黑客防线网安网讯:插入视图的条件:  1.假如视图是基于一个基础表产生的,那么这就称为非连接视图,所有的非连接视图都是可以更新的,也就是说可以在该视图上进行,INSERT,UPDATE,DELETE的操作.  2.假如是连接视图...

插入视图的条件: 

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表能够查询到该表或者视图是否可更新 Trackback: http://tb.blog.csdn.net/TrackBack.ASPx?PostId=1490248

    黑客防线网安服务器维护方案本篇连接:http://www.rongsen.com.cn/show-12267-1.html
网站维护教程更新时间:2012-03-23 00:38:41  【打印此页】  【关闭
我要申请本站N点 | 黑客防线官网 |  
专业服务器维护及网站维护手工安全搭建环境,网站安全加固服务。黑客防线网安服务器维护基地招商进行中!QQ:29769479

footer  footer  footer  footer