欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > Oracle 錯誤日志表及異常處理包詳解 附源碼

Oracle 錯誤日志表及異常處理包詳解 附源碼

熱門標簽:杭州網絡外呼系統運營商 鶴壁電話機器人價格 汽車4s店百度地圖標注店 手機地圖標注門店 電銷套路機器人 安陽企業電銷機器人供應商 網貸外呼系統合法嗎 地圖標注坐標圖標 地圖標注效果的制作

1 概述

1. 目的:'快速定位程序異常'

2. 包處理的核心思想:'自治事務' -- 自治事務的 "提交、回滾" 與 主事務 之間互不影響

3. 錯誤異常記錄邏輯大體一致,此處記錄,方便需要使用時復制、粘貼

4. 驗證思路:通過執行報錯的過程,觀察 '程序執行結果' 和 '日志表' 數據插入情況

2 效果演示

程序執行截圖:

日志表查詢截圖:

3 源碼

說明:
1. 測試中,共有 2 個用戶 -- 模擬實際開發場景
  (1) odsdata: 存放業務數據
  (2) odscde : 執行具體操作
  -- 為了方便測試,也可以去掉所有 '屬主 owner'

3.1 錯誤日志表

CREATE TABLE odsdata.ods_program_error_log (
 error_log_id    VARCHAR2(10) NOT NULL, -- CONSTRAINT pk_opel_error_log_id PRIMARY KEY(error_log_id)
 owner        VARCHAR2(30),
 package_name    VARCHAR2(30),
 procedure_name   VARCHAR2(30),
 error_comment    VARCHAR2(1000),
 error_backtrace   VARCHAR2(400),
 error_stack     VARCHAR2(4000),
 call_stack     VARCHAR2(4000),
 error_date     DATE NOT NULL,
 oracle_execute_user VARCHAR2(50),
 um_id        VARCHAR2(50)
);

COMMENT ON TABLE odsdata.ods_program_error_log IS '程序錯誤日志表';
COMMENT ON COLUMN odsdata.ods_program_error_log.error_log_id IS '錯誤日志id';
COMMENT ON COLUMN odsdata.ods_program_error_log.owner IS '屬主';
COMMENT ON COLUMN odsdata.ods_program_error_log.package_name IS '包名';
COMMENT ON COLUMN odsdata.ods_program_error_log.procedure_name IS '過程名';
COMMENT ON COLUMN odsdata.ods_program_error_log.error_comment IS '錯誤備注';
COMMENT ON COLUMN odsdata.ods_program_error_log.error_backtrace IS '錯誤跟蹤';
COMMENT ON COLUMN odsdata.ods_program_error_log.error_stack IS '錯誤堆棧';
COMMENT ON COLUMN odsdata.ods_program_error_log.call_stack IS '調用堆棧';
COMMENT ON COLUMN odsdata.ods_program_error_log.error_date IS '錯誤時間';
COMMENT ON COLUMN odsdata.ods_program_error_log.oracle_execute_user IS 'oracle執行用戶';
COMMENT ON COLUMN odsdata.ods_program_error_log.um_id IS '操作人員um賬號';

GRANT SELECT, INSERT, UPDATE ON odsdata.ods_program_error_log TO odscde;

3.2 異常處理包

擴展:Oracle 序列詳解(sequence)

package:

CREATE OR REPLACE PACKAGE odscde.pkg_ods_error_handle IS
 --*************************************************
 --功能說明: 錯誤日志
 --參數說明: i_procedure_name 程序名
 --     i_error_comment  錯誤備注(手工添加的)
 --調用函數:
 --修改記錄: create by YoYo 2020-12-17
 --*************************************************
 PROCEDURE exception_handle(i_procedure_name IN VARCHAR2,
               i_error_comment IN VARCHAR2);
END pkg_ods_error_handle;

package body:

CREATE OR REPLACE PACKAGE BODY odscde.pkg_ods_error_handle IS
 --*************************************************
 --功能說明: 錯誤日志
 --參數說明: i_procedure_name 程序名
 --     i_error_comment  錯誤備注(手工添加的)
 --調用函數:
 --修改記錄: create by YoYo 2020-12-17
 --*************************************************
 PROCEDURE exception_handle(i_procedure_name IN VARCHAR2,
               i_error_comment IN VARCHAR2) IS
  PRAGMA AUTONOMOUS_TRANSACTION; -- !!! 自治事務
  v_log_info odsdata.ods_program_error_log%ROWTYPE;
 BEGIN
  v_log_info.error_log_id    := '1'; -- 異常錯誤id(一般是 "獲取序列號",此處僅演示)
  v_log_info.procedure_name   := i_procedure_name; -- 程序名
  v_log_info.error_comment    := i_error_comment;
  v_log_info.oracle_execute_user := sys_context('USERENV', 'SESSION_USER'); -- oracle執行用戶
  v_log_info.um_id        := nvl(sys_context('USERENV', 'OS_USER'),
                     USER); -- 操作人員um賬號
  v_log_info.error_backtrace   := dbms_utility.format_error_backtrace; -- 錯誤跟蹤
  v_log_info.error_stack     := dbms_utility.format_error_stack; -- 錯誤堆棧
  v_log_info.call_stack     := dbms_utility.format_call_stack; -- 調用堆棧
  v_log_info.error_date     := SYSDATE;
 
  -- 可選列
  ---- 包屬主
  v_log_info.owner := substr(v_log_info.error_backtrace,
                instr(v_log_info.error_backtrace, '"', 1) + 1,
                (instr(v_log_info.error_backtrace, '.', 1) -
                instr(v_log_info.error_backtrace, '"', 1) - 1));
  ---- 包名
  v_log_info.package_name := substr(v_log_info.error_backtrace,
                   instr(v_log_info.error_backtrace,
                      '.',
                      1) + 1,
                   (instr(v_log_info.error_backtrace,
                       '"',
                       1,
                       2) - instr(v_log_info.error_backtrace,
                             '.',
                             1) - 1));
 
  -- 插入數據
  INSERT INTO odsdata.ods_program_error_log
   (error_log_id,
    owner,
    package_name,
    procedure_name,
    error_comment,
    error_backtrace,
    error_stack,
    call_stack,
    error_date,
    oracle_execute_user,
    um_id)
  VALUES
   (v_log_info.error_log_id,
    v_log_info.owner,
    v_log_info.package_name,
    v_log_info.procedure_name,
    v_log_info.error_comment,
    v_log_info.error_backtrace,
    v_log_info.error_stack,
    v_log_info.call_stack,
    v_log_info.error_date,
    v_log_info.oracle_execute_user,
    v_log_info.um_id);
 
  COMMIT;
 END exception_handle;
END pkg_ods_error_handle;

3.3 測試程序

演示報錯:違反唯一性約束

stu_info:

CREATE TABLE odsdata.stu_info (
 sno  NUMBER(10) CONSTRAINT pk_si_sno PRIMARY KEY,
 sname VARCHAR2(50) NOT NULL
);

GRANT SELECT, INSERT, UPDATE ON odsdata.stu_info TO odscde;

INSERT INTO odsdata.stu_info(sno, sname) VALUES(1, '瑤瑤');
COMMIT;

package:

CREATE OR REPLACE PACKAGE odscde.pkg_ods_error_test AS
 PROCEDURE ods_error_test(o_flag  OUT VARCHAR2,
              o_message OUT VARCHAR2);
END pkg_ods_error_test;

package body:

CREATE OR REPLACE PACKAGE BODY odscde.pkg_ods_error_test AS
 PROCEDURE ods_error_test(o_flag  OUT VARCHAR2,
              o_message OUT VARCHAR2) IS
  i_procedure_name VARCHAR2(30) := 'ods_error_test';
 BEGIN
  INSERT INTO odsdata.stu_info (sno, sname) VALUES (1, '瑤瑤');
  COMMIT;
 
  o_flag  := 'Y';
  o_message := '執行成功!';
 EXCEPTION
  WHEN OTHERS THEN
   o_flag  := 'N';
   o_message := '執行失??!';
   pkg_ods_error_handle.exception_handle(i_procedure_name => i_procedure_name,
                      i_error_comment => '' -- 關鍵入參、出參
                      );
 END ods_error_test;
END pkg_ods_error_test;

到此這篇關于Oracle 錯誤日志表及異常處理包詳解 附源碼的文章就介紹到這了,更多相關Oracle 錯誤日志表內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 解決python3捕獲cx_oracle拋出的異常錯誤問題
  • 詳解Oracle自定義異常示例
  • Oracle中RAISE異常深入分析
  • win7安裝oracle10g 提示程序異常終止 發生未知錯誤
  • oracle異常(預定義異常,自定義異常)應用介紹

標簽:柳州 泰安 銀川 酒泉 梧州 焦作 河源 南陽

巨人網絡通訊聲明:本文標題《Oracle 錯誤日志表及異常處理包詳解 附源碼》,本文關鍵詞  Oracle,錯誤,日志,表,及,異常,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Oracle 錯誤日志表及異常處理包詳解 附源碼》相關的同類信息!
  • 本頁收集關于Oracle 錯誤日志表及異常處理包詳解 附源碼的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    国产一线在线观看| 欧美精品18+| 国产色综合久久| 久久精工是国产品牌吗| 91传媒理伦片在线观看| 欧美日韩一二三| 亚洲影视在线播放| 少妇欧美激情一区二区三区| 在线免费精品视频| 亚洲美女视频在线观看| 99精品国产热久久91蜜凸| 国产一二三四区| 国产精品久久久久久久久果冻传媒| 狠狠色2019综合网| 国产日产在线观看| 欧美经典一区二区| 大桥未久av一区二区三区中文| 久久视频一区二区三区| 国产亚洲成av人在线观看导航| 国产一区二区福利| 无码人妻精品中文字幕| 国产精品亲子乱子伦xxxx裸| 成人精品免费视频| 2021亚洲天堂| 一区二区三区 在线观看视频| 国产精品99久久久精品无码| 欧美久久免费观看| 日本一区中文字幕 | 妖精视频在线观看| 欧美美女网站色| 日韩精品视频网| 国产aⅴ激情无码久久久无码| 2019国产精品| 岛国精品在线播放| 欧美系列一区二区| 亚洲成人手机在线| 毛片网站免费观看| 亚洲国产精品av| 91在线高清观看| 91精品婷婷国产综合久久竹菊| 蜜臀av在线播放一区二区三区| 亚洲色图第四色| 亚洲视频在线一区二区| 国产av一区二区三区传媒| 日韩欧美电影一区| 国产99久久久国产精品| 欧美少妇一区二区| 男男成人高潮片免费网站| 国产成人免费在线观看视频| 伊人夜夜躁av伊人久久| 最近中文字幕无免费| 久久精品一级爱片| 91在线免费视频观看| 日韩一区二区三区av| 国产一本一道久久香蕉| 在线观看亚洲精品| 日本va欧美va瓶| 国产在线一卡二卡| 视频一区免费在线观看| 影音先锋男人看片资源| 伊人开心综合网| 一级片视频免费看| 亚洲激情成人在线| 五月婷六月丁香| 亚洲曰韩产成在线| eeuss中文字幕| 亚洲午夜精品网| 黄色片网站免费| 夜夜嗨av一区二区三区中文字幕 | 国产欧美日韩在线| 国产精久久久久| 日本一区二区三区四区在线视频| 美女流白浆视频| 国产日韩v精品一区二区| 少妇献身老头系列| 国产欧美日韩视频在线观看| 91年精品国产| 国产欧美日韩精品在线| 日本一区二区免费视频| 国产精品久久久久久久久免费丝袜| 欧美xxxx×黑人性爽| 国产精品国产三级国产普通话99| 午夜剧场免费看| 亚洲婷婷在线视频| 四季av中文字幕| 三级一区在线视频先锋| 色老汉av一区二区三区| 久久精品国产99久久6| 欧美日韩免费不卡视频一区二区三区| 国产酒店精品激情| 欧美一级黄色录像| 日本少妇激三级做爰在线| 国产偷v国产偷v亚洲高清| 国产成人精品无码片区在线| 成人免费视频在线观看| 黄色av片三级三级三级免费看| 天天操天天干天天综合网| 在线观看国产日韩| 成人深夜视频在线观看| 国产三级欧美三级| 亚洲成人网在线播放| 亚洲chinese男男1069| 91久久精品一区二区三| 国产成人在线免费| 久久日韩粉嫩一区二区三区| 波多野结衣影院| 亚洲第一在线综合网站| 在线这里只有精品| 成人免费视频caoporn| 国产日韩欧美不卡| 中国女人特级毛片| 免费观看在线色综合| 欧美日韩国产综合视频在线观看| 99久久精品国产一区二区三区 | 亚洲蜜桃精久久久久久久久久久久| 一区二区日韩av| 在线观看免费视频综合| 99精品欧美一区二区蜜桃免费| 国产精品乱码一区二三区小蝌蚪| 国产调教在线观看| 精久久久久久久久久久| 精品国产一区久久| 国产精品扒开腿做爽爽| 伦理电影国产精品| 精品国产乱码久久久久久影片| 欧美大片免费播放器| 日韩二区在线观看| 日韩网站在线看片你懂的| 无码一区二区精品| 日韩av网站在线观看| 欧美一区国产二区| av2014天堂网| 偷拍日韩校园综合在线| 91精品国产欧美日韩| 五月开心播播网| 日本伊人精品一区二区三区观看方式 | 逼特逼视频在线观看| 一卡二卡欧美日韩| 在线播放日韩导航| 亚洲成人日韩在线| 精品一区二区免费视频| 国产亚洲一区二区三区在线观看| 国产3级在线观看| 成人精品国产免费网站| 亚洲美女淫视频| 欧美精品丝袜中出| 熟女少妇一区二区三区| 国产一区二区三区不卡在线观看 | 精品久久久久久久人人人人传媒 | 国产一区二区三区精品视频| 国产清纯在线一区二区www| 99热在线观看精品| 99精品久久只有精品| 亚洲成人自拍网| 日韩精品在线看片z| 成年人看的免费视频| 成人久久18免费网站麻豆| 一区二区三区四区在线免费观看 | jlzzjizz在线播放观看| 久久超碰97中文字幕| 欧美韩日一区二区三区四区| 欧美卡一卡二卡三| 精品一区二区三区四区五区六区| 免费看日韩a级影片| 欧美—级在线免费片| 91极品视觉盛宴| www.88av| 国产91丝袜在线18| 亚洲小说欧美激情另类| 精品免费日韩av| 永久免费看黄网站| 欧美xxxxx精品| 国产一区二区三区日韩| 亚洲欧美一区二区三区孕妇| 欧美一区二区在线免费观看| 亚洲欧美另类日本| 香蕉视频在线观看黄| 伦理电影国产精品| 亚洲另类色综合网站| 日韩一级大片在线| 国产97免费视频| 免费a v网站| 国产福利一区二区三区视频在线| 一区二区三区**美女毛片| 精品国产乱码久久久久久牛牛| 一本久久精品一区二区| 内射中出日韩无国产剧情| 粉嫩蜜臀av国产精品网站| 亚洲一区视频在线| 久久精品人人做人人综合| 欧美性大战久久| 欧美一区二区三区粗大| 99re热这里只有精品视频| 毛片一区二区三区| 亚洲精品老司机| 久久一夜天堂av一区二区三区| 91黄色免费看| 亚洲一二三四视频| 大桥未久恸哭の女教师| 国产成人在线网站|