Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2549148
  • 博文数量: 2110
  • 博客积分: 18861
  • 博客等级: 上将
  • 技术积分: 24420
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-05 18:23
文章分类

全部博文(2110)

文章存档

2011年(139)

2010年(1971)

我的朋友

分类: Oracle

2010-03-10 15:27:53

 单表创建的视图是可以增、删、改。多表创建的视图是不能直接进行视图添加等更新。

  解决办法:替代触发器。说道这,大家可能就都知道怎么做了。

  create or replace trigger 名称

  Instead Of Insert or update or delete

  on 视图

  for each row

  Declare

  begin

  If Inserting Then

  Insert Into 基本表1 (t11,t12) Values (:New.f1,:New.f2);

  Insert Into 基本表2 (t11,t22) Values (:New.f1,:New.f3);

  elsif Updating Then

  Update 基本表1 set t11=:New.f1,t12=:New.f2 where t11=:New.f1;

  Update 基本表2 set t11=:New.f1,t22=:New.f3 where t11=:New.f1;

  elsif Deleting then

  Delete from 基本表1 where t11=:Old.f1;

  Delete from 基本表2 where t11=:Old.f1;

阅读(357) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~