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

2016-02-19 09:51 292 1 收藏

图老师小编精心整理的在Oracle中向视图中插入数据的方法希望大家喜欢,觉得好的亲们记得收藏起来哦!您的支持就是小编更新的动力~

【 tulaoshi.com - 编程语言 】

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

来源:http://www.tulaoshi.com/n/20160219/1592429.html

延伸阅读
1.在ORACLE中实现SELECT TOP N    由于ORACLE不支持SELECT TOP语句,所以在ORACLE中经常是用ORDER BY跟ROWNUM的组合来实现SELECT TOP N的查询。   简单地说,实现方法如下所示:   SELECT 列名1...列名n FROM     (SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n) &...
在PPT中插入视频播放的方法   1、支持的视频格式如下: 2、新建一个块,或者选择一个,右键,选择动作设置,选择运行程序 3、放上你的播放器的路径 并且空一格,后面放上视频文件的完整名称就可以了 注意:播放器要在机器上有,最好是绿色的,如果跨机器播放,请把播放器也一并带上,并且文件都要放在一个目录下 ...
/* * 创建日期 2005-9-27 * * TODO 要更改此生成的文件的模板,请转至 * 窗口 - 首选项 - Java - 代码样式 - 代码模板 */ package person.fane.test; import java.sql.*; /** * A JDBC test application for Oracle * @author Fane * @version 1.0.0 * @since JDK1.4 */ ...
在当今信息化高速发展的时代,日常的工作中,用户经常遇到要将EXCEL文件中的数据和ORACLE数据库中的数据互倒的问题,实现对实时数据的操作,而可查阅到这方面的资料并不多。若需将ORACLE信息系统中的数据倒出来,并在此基础上利用EXCEL对其进行分析整理,笔者在工作中利用ODBC将数据倒入到EXCEL文件中,对初学者来说,效果不错,在这里给大...
标签: word
怎样在Word2013页面视图中显示背景色   第1步,打开Word2013文档窗口,依次单击文件→选项按钮。 第2步,打开Word选项对话框,切换到高级选项卡。在显示文档内容区域选中在页面视图中显示背景色和图像复选框,并单击确定按钮。 小提示:如果需要取消显示背景色,则取消选中在页面视图中显示背景色和图像复选框即...

经验教程

106

收藏

10
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部