av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

Oracle外部程序的觸發小結

瀏覽:144日期:2023-11-21 17:32:07
在論壇里曾經看過一個帖子,有位用戶問了這么一個問題:Oracle 里一個表插入一條數據,提交后,如何讓外部程序收到這個消息? 當時沒有留意,現在想想似乎應該可以總結一下了。舉例: 1、過程中: ... declare myexcept exception; inserted_count1 number; inserted_count2 number; ... begin insert into table values(...); inserted_count1 := sql%rowcount; ... --可以判定inserted_count1是否大于0來確定是否插入了數據 commit; inserted_count2 := sql%rowcount; --這里inserted_count2為0 ... --事實上,這里一定是提交成功才會執行,否則會跳到exception段 yourprocess(yourpara);--調用你自己的過程或語句跟別的過程通信 ... exception when others then ---你可以根據sqlcode自己去查具體的提交失敗原因 ... yourprocess_for_fail(yourpara) --調用你自己的過程跟別的過程通信 ... end;2、直接外部操作,建觸發器: create or replace trigger table after insert for each row ... begin ... yourprocess(yourprara); ... end; 當然,2的方法這只能更總到提交前,假如要監視提交后狀態,你可以在操作表建立標志位或專門建個表,操作表發生變化就通過trigger更新變化信息到狀態表,掃描狀態表就知道是否commit;成功了 我想這位用戶應該通過trigger來調用Java source來實現插入數據后來通知外部程序來做一些事情: 使用java source的例子如下: SQL> create or replace and compile java source named HelloWorld 2 as 3 public class HelloWorld { 4 public static void db_run (){ 5 System.out.println('Hello World'); 6 } 7 } 8 / Java created. SQL> create or replace procedure run_helloworld 2 as language java 3 name 'HelloWorld.db_run()'; 4 / Procedure created. SQL> set serveroutput on size 5000 SQL> call dbms_java.set_output(5000) ; Call completed. SQL> SQL> exec run_helloworld ; Hello World PL/SQL procedure sUCcessfully completed. 上面是調用HelloWorld的例子,你可以修改HelloWorld方法,然后在觸發器里面調用以實現這位用戶的要求!
標簽: Oracle 數據庫
主站蜘蛛池模板: 欧美三级电影在线播放 | 国产精品精品视频一区二区三区 | av电影手机版 | 亚洲一区二区精品 | 韩日免费视频 | 精品久久国产 | 天天综合久久 | 欧美激情在线精品一区二区三区 | 黄 色 毛片免费 | 国产精品久久久久免费 | 久久99精品视频 | 日韩欧美高清 | 国产欧美一级 | 亚洲 一区 | 日日夜夜精品视频 | 成人h片在线观看 | 国产激情在线 | 国产资源视频 | 日韩在线一区二区 | 日韩欧美大片在线观看 | 日本不卡一二三 | 成人动漫一区二区 | 精品国产精品三级精品av网址 | 国产高清精品一区二区三区 | 福利视频网站 | 国产精品黄色 | 色噜噜色综合 | 欧美精品久久久久 | 国内av在线| 亚洲国产欧美日韩 | 日本一区二区高清不卡 | 一区二区三区视频在线观看 | 欧美aaaaaaaa | 国产亚洲精品久久久久动 | 91精品久久久久 | 91aiai| 中文字幕啪啪 | 欧美成人一区二区 | 国产精品视频在线观看 | 成人精品久久 | 91亚洲精华国产 |