ITPub博客

34、VIEW可以insert,delete,update.

原创 作者:yyycxhtx 时间:2007-12-12 16:00:18 0 删除 编辑

试图是可以insert ,delete,update的,但是要满足一定的条件。所有的这些条件最终都反映在基表上,必须遵从基表的约束,并且也会触发定义在基表上的trigger

[@more@]

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就不是主码了,所以为非码保留表.

下一篇: 35、SCN号的理解
请登录后发表评论 登录
全部评论
  • 博文量
    39
  • 访问量
    57026