服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > 数据库技术 > Oracle技术 > Oracle开发 > 查看文档

菜鸟课堂:oracle里向视图中插入数据方法

插入视图的条件:

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表能够查询到该表或者视图是否可更新。

扫描关注微信公众号