亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 編程設計 > 正文

oracle觸發器使用總結

2020-06-27 15:21:35
字體:
來源:轉載
供稿:網友

觸發器 是特定事件出現的時候,自動執行的代碼塊。類似于存儲過程,但是用戶不能直接調用他們。觸發器是許多關系數據庫系統都提供的一項技術。在ORACLE系統里,觸發器類似過程和函數,都有聲明,執行和異常處理過程的PL/SQL塊。

1.說明

1)觸發器是一種特殊的存儲過程,觸發器一般由事件觸發并且不能接受參數,存儲器由語句塊去調用

2)觸發器分類:

  1.DML觸發器: 創建在表上,由DML事件引發

  2.instead of觸發器: 創建在視圖上并且只能在行級上觸發,用于替代insert,delete等操作(由于oracle中不能直接對有兩個以上的表建立的視圖進行DML操作,所以給出替代觸發器,它是專門為進行視圖操作的一種處理方法)

  3.DDL觸發器: 觸發事件時數據庫對象的創建和修改

  4.數據庫事件觸發器:定義在數據庫或者模式上,由數據庫事件觸發

3)組成:

  1.觸發事件:引發觸發器被觸發的事件 DML語句(INSERT, UPDATE, DELETE語句對表或視圖執行數據處理操作)、DDL語句(如CREATE、ALTER、DROP語句在數據庫中創建、修改、刪除模式對象)、數據庫系統事件

     ?。ㄈ缦到y啟動或退出、異常錯誤)、用戶事件(如登錄或退出數據庫)。

  2.觸發時間:即該觸發器是在觸發事件發生之前(BEFORE)還是之后(AFTER)觸發

  3.觸發操作:觸發器觸發后要完成的事情

  4.觸發對象:包括表、視圖、模式、數據庫。只有在這些對象上發生了符合觸發條件的觸發事件,觸發器才會執行觸發操作。

  5.觸發條件:由WHEN子句指定一個邏輯表達式。只有當該表達式的值為TRUE時,遇到觸發事件才會自動執行觸發操作。

  6.觸發頻率:說明觸發器內定義的動作被執行的次數。即語句級(STATEMENT)觸發器和行級(ROW)觸發器。(比如delete多條數據時,行級觸發器可能會執行多次,語句級觸發器只會觸發一次)       

2.語法

1)說明

不同類型的觸發器例如DML觸發器,Instead of觸發器,系統觸發器語法格式區別較大

2)一般語法

  CREATE [OR REPLACE] TIGGER觸發器名 觸發時間 觸發事件  ON表名/視圖名  [FOR EACH ROW]  //加上FOR EACH ROW 即為行級觸發器,不加時為語句級觸發器  BEGIN  pl/sql語句  END
    create [or replace] trigger [schema.]trigger_name      {before | after | instead of}      {delete [or insert][or update [of column,...n]]}      on [schema.]table_name | view_name      [for each row [when(condition)]]      sql_statement[,...n]

例如:

  CREATE OR REPLACE TRIGGER   trigger_name    < before | after | instead of > < insert | update | delete>  ON table_name  [FOR EACH ROW]  WHEN (condition)  DECLARE  BEGIN  END;

3)instead of 觸發器語法

語法:

CREATE [OR REPLACE] TRIGGER trigger_name INSTEAD OF{INSERT|DELETE|UPDATE [OF COLUMN...]}[OR {INSERT| DELETE| UPDATE [OF COLUMN...]}]ON VIEW_NAME[REFFERENCING{OLD [AS] OLD | NEW [AS] NEW| PARENT AS PARENT}]   // 可以指定相關名稱,當前的默認相關名稱為OLD和NEW,應用相關名稱時需要加:[FOR EACH ROW]  //instead of 觸發器只能在行級上觸發,因為沒有必要指定[WHEN CONDITION]DECLAREBEGINEND;

說明:INSTEAD OF 用于對視圖的DML觸發,由于視圖可能有多個表進行聯結而成,因而并非所有的聯結均可更新,運用 INSTEAD OF 觸發器可完成相應的操作。

3.實例

創建測試表格:

CREATE TABLE "HNZC"."TRIGGERTEST"  (    "ID"    VARCHAR2(20 BYTE),    "NAME"  VARCHAR2(20 BYTE),    "SCORE" NUMBER  );create table tab1 select * from triggertest;

1)DML觸發器/行級觸發器

觸發器如下:

CREATE OR REPLACE TRIGGER TRIGGER1 AFTER INSERT ON TRIGGERTEST    //插入后觸發FOR EACH ROW                   //行級觸發器BEGIN   INSERT INTO tab1(ID,NAME) VALUES('22','33');END;

執行語句:

insert into triggertest (id) values ('aabbcc');

語句執行結束,表tab1中新增加一條數據

2)限制對表的修改(例如非工作時間不能修改某些表)

觸發器如下:

CREATE OR REPLACE TRIGGER TRIGGER1 AFTER INSERT ON TRIGGERTEST FOR EACH ROW BEGIN   IF(TO_CHAR(SYSDATE,'DAY') IN ('星期三','星期天'))   THEN RAISE_APPLICATION_ERROR(-20001,'不是上班時間,不能修改表格triggertest');   END IF;END;

執行語句:

insert into triggertest (id) values ('aabbcc');

今天周三因而輸出結果為:

在行 1 上開始執行命令時出錯:insert into triggertest (id) values ('aabbcc')錯誤報告:SQL 錯誤: ORA-20001: 不是上班時間,不能修改表格triggertestORA-06512: 在 "HNZC.TRIGGER1", line 3ORA-04088: 觸發器 'HNZC.TRIGGER1' 執行過程中出錯

通常對表的修改限制如下(即周一至周五9——18點能修改表格)

CREATE OR REPLACE TRIGGER TRIGGER1 BEFORE INSERT OR DELETE OR UPDATE ON TRIGGERTEST FOR EACH ROW BEGIN   IF(TO_CHAR(SYSDATE,'DAY') IN ('星期六','星期天'))   OR(TO_CHAR(SYSDATE,'HH24:MI') NOT BETWEEN '9:00' AND '18:00')   THEN RAISE_APPLICATION_ERROR(-20001,'不是上班時間,不能修改表格triggertest');   END IF;END;

3)增加限制條件(如不能更改某個員工的記錄)

觸發器如下:(如下實現月兒的分數只能增加)

CREATE OR REPLACE TRIGGER TRIGGER1 BEFORE INSERT OR DELETE OR UPDATE ON TRIGGERTEST FOR EACH ROW WHEN(OLD.NAME='月兒')BEGIN   CASE WHEN UPDATING('SCORE') THEN        IF:NEW.SCORE<:OLD.SCORE        THEN RAISE_APPLICATION_ERROR(-20001,'月兒的分數只能提升不能下降');        END IF;    END CASE;END;

當前月兒的分數為20

當修改為10時出錯

UPDATE "HNZC"."TRIGGERTEST" SET SCORE = '10' WHERE ROWID = 'AAAdEzAAPAAAAH+AAB' AND ORA_ROWSCN = '47685303'ORA-20001: 月兒的分數只能提升不能下降ORA-06512: 在 "HNZC.TRIGGER1", line 4ORA-04088: 觸發器 'HNZC.TRIGGER1' 執行過程中出錯

當修改為30時成功

UPDATE "HNZC"."TRIGGERTEST" SET SCORE = '30' WHERE ROWID = 'AAAdEzAAPAAAAH+AAB' AND ORA_ROWSCN = '47685303'提交成功

4)在觸發器中調用存儲過程

觸發器為:

CREATE OR REPLACE TRIGGER TRIGGER1 BEFORE INSERT OR DELETE OR UPDATE ON TRIGGERTEST FOR EACH ROW BEGIN  TESTPRO1();END;

存儲過程為:

create or replacePROCEDURE TESTPRO1 AS BEGIN insert into tab1(id,name,score) VALUES('AAA','BBB',200);END TESTPRO1;

執行完畢后tab1中增加一條數據

5)級聯更新

觸發器如下(triggertest表中name修改時同時修改tab1中的name)

create or replacePROCEDURE TESTPRO1 AS BEGIN insert into tab1(id,name,score) VALUES('AAA','BBB',200);END TESTPRO1;

執行語句:

update  triggertest set name= '水兒' where name='月兒';

結果:tab1中name為月兒的也更改為水兒

6)instead of觸發器

TABLE STUDENT表格數據如下

oracle

創建視圖student_view

CREATE OR REPLACE VIEW STUDNET_VIEW AS SELECT CLASSID,AVG(SCORE) AVERAGE_SCORE FROM STUDENTGROUP BY CLASSID;

視圖數據如下:

oracle

對視圖student_view 執行如下操作:

DELETE FROM STUDNET_VIEW WHERE CLASSID='111';

執行結果:

錯誤報告:SQL 錯誤: ORA-01732: 此視圖的數據操縱操作非法01732. 00000 -  "data manipulation operation not legal on this view"

解決方法:創建INSTEAD OF 視圖

CREATE OR REPLACE TRIGGER STUDENT_VIEW_DELETE INSTEAD OF DELETE ON STUDNET_VIEW FOR EACH ROWBEGIN  DELETE FROM STUDENT WHERE CLASSID=:OLD.CLASSID;END STUDENT_VIEW_DELETE;

執行刪除語句

DELETE FROM STUDNET_VIEW WHERE CLASSID='111';

執行結果:刪除成功

1 行已刪除。

4.注意事項

1) 在觸發器的執行部分只能用DML語句(SELECT、INSERT、UPDATE、DELETE),不能使用DDL語句(CREATE、ALTER、DROP)

2) 觸發器中不能使用commit語句,觸發器的操作與觸發事件(INSERT,UPDATE,DELETE)一起進行COMMIT和ROLLBACK;

3)  一個表上的觸發器越多,對于表的DML操作性能影響越大

4) 觸發器最大為32K


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文国产亚洲喷潮| 国产精品永久在线| 91网站在线看| 亚洲va码欧洲m码| 7777免费精品视频| 国产成人小视频在线观看| 国产精品∨欧美精品v日韩精品| 永久555www成人免费| 欧美另类极品videosbestfree| 亚洲男人天堂古典| 欧美激情视频免费观看| 欧美黄色小视频| 国产成人a亚洲精品| 欧美电影免费观看电视剧大全| 亚洲国产精品999| 国产欧美精品久久久| 91精品国产网站| 高潮白浆女日韩av免费看| 欧美激情手机在线视频| 2021久久精品国产99国产精品| 欧美大片va欧美在线播放| 91精品国产亚洲| 国内免费精品永久在线视频| 国产欧美日韩中文| 精品二区三区线观看| 国产有码在线一区二区视频| 精品欧美aⅴ在线网站| 亚洲国产成人精品电影| 永久免费精品影视网站| 欧美午夜精品伦理| 亚洲一区美女视频在线观看免费| 日韩欧美在线一区| 国产亚洲人成a一在线v站| 国产精品丝袜白浆摸在线| 欧美国产日韩视频| 久久精视频免费在线久久完整在线看| 97精品一区二区视频在线观看| 日本一本a高清免费不卡| 97久久超碰福利国产精品…| www国产亚洲精品久久网站| 国产精品海角社区在线观看| 亚洲欧美国产日韩中文字幕| 国产狼人综合免费视频| 一区二区三区美女xx视频| 中文字幕日韩专区| 69av成年福利视频| 91精品国产九九九久久久亚洲| 亚洲人在线视频| 高清日韩电视剧大全免费播放在线观看| 91九色国产社区在线观看| 日韩av不卡电影| 亚洲欧美日韩高清| 欧美精品18videosex性欧美| 亚洲色图第三页| 亚洲久久久久久久久久久| 精品久久久久久久久久久久久| 国语自产在线不卡| 国产精品美女999| 亚洲欧美日韩图片| 成人欧美一区二区三区在线| 国产精品美女主播| 丝袜情趣国产精品| 国产精品午夜一区二区欲梦| 视频一区视频二区国产精品| 菠萝蜜影院一区二区免费| 国产不卡在线观看| 亚洲第一福利视频| 国产精品偷伦一区二区| 国产精品成熟老女人| 日韩精品亚洲元码| 中文字幕9999| 久久国产精品久久精品| 成人网欧美在线视频| 国产精品日韩电影| 久久久久久久久国产| 日韩美女写真福利在线观看| 成人午夜高潮视频| 国产有码一区二区| 欧美大尺度电影在线观看| 亚洲美腿欧美激情另类| 日韩av综合网站| 日韩中文字幕视频在线观看| 国产精品视频1区| 国产区精品在线观看| 亚洲电影中文字幕| 超碰精品一区二区三区乱码| 欧美大尺度电影在线观看| 亚洲国产一区二区三区四区| 成人日韩在线电影| 日韩免费在线播放| 欧美在线xxx| 精品亚洲男同gayvideo网站| 日韩免费观看av| 夜色77av精品影院| 欧美日韩国产成人在线观看| 国产精品美女999| 97视频在线免费观看| 日韩精品电影网| 亚洲xxx大片| 91免费在线视频| 亚洲人成电影网站色| 国产精品久久久久一区二区| 久久久久久久久久久网站| 欧美性感美女h网站在线观看免费| 亚洲精品xxx| 欧美国产乱视频| 日韩视频免费在线观看| 欧美日韩中文在线观看| 亚洲精品美女在线观看播放| 国内自拍欧美激情| 91精品国产色综合| 欧美电影在线观看高清| 国产欧美日韩精品丝袜高跟鞋| 亚洲深夜福利网站| 久久亚洲私人国产精品va| 亲爱的老师9免费观看全集电视剧| 日韩美女视频免费在线观看| 亚洲人成77777在线观看网| 久久好看免费视频| 日韩精品丝袜在线| 国产女精品视频网站免费| 亚洲一区二区在线| 久久亚洲精品成人| 日韩精品极品在线观看| 亚洲成色777777在线观看影院| 国产精品美女午夜av| 久久精品国产久精国产思思| 午夜精品蜜臀一区二区三区免费| 日韩av一区在线| 国产色视频一区| 青青久久av北条麻妃黑人| 日本精品久久久久久久| 97精品国产97久久久久久| 国产香蕉97碰碰久久人人| 久久影视电视剧凤归四时歌| 中文字幕欧美亚洲| 亚洲精品一区二区久| 中文字幕精品久久| 亚洲精品91美女久久久久久久| 日韩欧美一区二区三区| 亚洲欧美自拍一区| 日韩欧美国产视频| 欧美激情视频在线| 欧美精品18videos性欧| 中文字幕欧美专区| 亚洲视频在线观看视频| 久久久久99精品久久久久| 国产日韩精品视频| 福利视频导航一区| 亚洲欧美成人一区二区在线电影| 国产美女精品视频免费观看| 91国产中文字幕| 欧美重口另类videos人妖| 日韩中文字幕精品| 久久国产精品免费视频| 在线性视频日韩欧美| 欧美国产日本高清在线| 欧美成人激情视频免费观看| 久久99久久久久久久噜噜| 国产日韩欧美在线视频观看| 亚洲另类图片色| 久久精品亚洲精品| 国产精欧美一区二区三区| 成人黄色av播放免费|