在Oracle中向视图中插入数据的方法
程序员文章站
2023-12-01 18:20:58
插入视图的条件: 1.如果视图是基于一个基础表产生的,那么这就称为非连接视图,所有的非连接视图都是可以更新的,也就是说可以在该视图上进行,inser...
插入视图的条件:
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表能够查询到该表或者视图是否可更新。
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表能够查询到该表或者视图是否可更新。
推荐阅读
-
在Oracle中向视图中插入数据的方法
-
用shell脚本在mysql表中批量插入数据的方法
-
在oracle 数据库查询的select 查询字段中关联其他表的方法
-
mssql 一次向表中插入多条数据的方法分享 (转自:http://www.maomao365.com/?p=6058)
-
用shell脚本在mysql表中批量插入数据的方法
-
MyBatis在Oracle中插入数据并返回主键的问题解决
-
在Oracle数据库中添加外键约束的方法详解
-
oracle数据库中批量把一张表里面的数据插入到不同的表中的方法
-
在Oracle数据库中同时更新两张表的简单方法
-
Extjs4.1向Ext.grid.Panel创建的gridpanel中动态在第一行插入数据