广

oracle数据库

  • MYSQL
  • MSSQL
  • Redis
  • MongoDB
  • oracle数据库
  • 数据管理

    Oracle中向视图中插入数据

    2018-04-13 09:16:39 次阅读 稿源:互联网
    广告
    全网推广平台,软文发布

    插入视图的条件: 

    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

    一起学吧部分文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与一起学吧进行文章共享合作。

    广告
    广告
    广告
    广告