Oracle中向视图中插入数据

2016-01-29 14:39 108 1 收藏

Oracle中向视图中插入数据,Oracle中向视图中插入数据

【 tulaoshi.com - 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

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com)

此外通过user_updatable_columns表能够查询到该表或者视图是否可更新。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com)

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1490248

来源:http://www.tulaoshi.com/n/20160129/1493848.html

延伸阅读
物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的。普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实际上转换为视图SQL语句的查询。这样对整体查询性能的提高,并没有实质上的好处。 Oracle最早在OLAP系统中引入了物化视图的概念。但后来很多大型OLTP系统中,发现类似统计的查询是无可...
标签: 办公软件
    在Word应用中,常常会调用到Access、Excel或其他数据库中的数据,如工资报表、学生成绩单等。常用的调用方法是运用复制与粘贴的方法将数据库中需要引入的数据复制到Word后再进行编辑,此种方式操作虽然比较简单,但却有一定的局限性。首先如果是有选择性地对某些符合条件的数据进行复制,需在原数据库中先对数据进行处...
完整性约束 完整性约束用于增强数据的完整性,Oracle提供了5种完整性约束: Check NOT NULL Unique Primary Foreign key 完整性约束是一种规则,不占用任何数据库空间。完整性约束存在数据字典中,在执行SQL或PL/SQL期间使用。用户可以指明约束是启用的还是禁用的,当约束启用时,他增强了...
什么是视图 视图犹如数据表的窗户,管理员定义这些窗户的位置后,用户就只能查看他可以看到的数据。视图不是数据表,它仅是一些SQL查询语句的集合,作用是按照不同的要求从数据表中提取不同的数据。 如何创建视图 (1)如图7.52所示。 (2)出现如图7.53所示的创建视图的选项卡。 (3)切换到如图7.54所示的创...
  当鼠标在视图区移动时,在鼠标附近同步显示鼠标所在的坐标位置。这个功能,对许多网友来说并不复杂。简单的办法是在OnDraw中绘制坐标位置就可以了。本文的实现思路是在不调用视图刷新以及不覆盖视图上原有内容的基础上实现鼠标坐标的跟踪显示。     1。鼠标移动前,计算显示的鼠标坐标字符串所要占的矩形位置。   2...

经验教程

515

收藏

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