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

来源:asp之家 时间:2009-02-28 10:42:00 

插入视图的条件:
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,视图,插入,数据
0
投稿

猜你喜欢

  • 详解Python执行py文件是否需要可执行权限

    2021-01-19 10:52:53
  • asp日历代码 显示农历

    2007-09-23 08:40:00
  • python包和文件夹有的区别点总结

    2022-05-09 11:59:01
  • python将txt文档每行内容循环插入数据库的方法

    2024-01-25 21:37:29
  • python实现打印类的所有属性和方法

    2021-07-28 14:51:56
  • python GUI库图形界面开发之PyQt5信号与槽的高级使用技巧装饰器信号与槽详细使用方法与实例

    2022-11-27 15:06:22
  • python 正则表达式 概述及常用字符

    2023-03-03 07:16:15
  • PHP设计模式之模板方法模式Template Method Pattern详解

    2023-05-25 00:24:26
  • ajax代理程序,自动判断字符编码

    2007-11-04 13:17:00
  • 解决Tensorflow 使用时cpu编译不支持警告的问题

    2023-12-30 07:28:01
  • python MySQLdb使用教程详解

    2024-01-28 06:29:51
  • Python Selenium操作Cookie的实例方法

    2022-10-22 10:21:34
  • 将Pytorch模型从CPU转换成GPU的实现方法

    2023-07-07 00:11:00
  • 一文详解Go中方法接收器的选择

    2024-05-28 15:36:32
  • python实现协同过滤推荐算法完整代码示例

    2023-10-11 00:29:05
  • python基础教程之udp端口扫描

    2022-01-10 01:03:22
  • 文档标准的真实谎言

    2008-06-02 10:46:00
  • FckEditor 配置手册中文教程详细说明

    2023-06-18 20:35:59
  • python-pymysql如何实现更新mysql表中任意字段数据

    2024-01-19 17:35:01
  • python机器学习之线性回归详解

    2022-10-20 19:14:49
  • asp之家 网络编程 m.aspxhome.com