婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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 錯誤日志表及異常處理包詳解 附源碼的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    bt7086福利一区国产| 国产成人综合在线观看| 亚洲国产精品久久久男人的天堂| 亚洲男人的天堂在线观看| 玖玖九九国产精品| 国产在线看一区| 欧美剧情片在线观看| 国产精品欧美一级免费| 国产高清精品久久久久| 成人av在线一区二区三区| 日韩美女视频在线| 亚洲品质自拍视频| 99re这里只有精品6| 国产欧美一区二区精品久导航| 久久精品国产亚洲一区二区三区| 欧美丰满美乳xxx高潮www| 亚洲一区二区三区四区的| 不卡欧美aaaaa| 日韩一区中文字幕| 99久久精品国产导航| 又紧又大又爽精品一区二区| 91黄视频在线| 开心九九激情九九欧美日韩精美视频电影 | 亚洲国产欧美一区二区三区丁香婷| 五月激情丁香一区二区三区| 欧美剧情片在线观看| 国产最新精品免费| 欧美日本免费一区二区三区| 久久精品国产精品青草| 中文字幕一区av| 欧美成人精品1314www| 国产精品综合在线视频| 一区二区三区久久| 久久日一线二线三线suv| 色婷婷激情一区二区三区| 青青草成人在线观看| 精品第一国产综合精品aⅴ| 在线观看网站黄不卡| 成人精品视频一区二区三区| 亚洲成va人在线观看| 国产欧美日韩不卡| xfplay精品久久| 91精品国产综合久久精品图片 | 精品一区二区免费在线观看| 亚洲一区二区三区视频在线播放| 中文字幕在线不卡一区二区三区 | 国产成人午夜精品5599| 麻豆视频观看网址久久| 亚洲国产精品久久艾草纯爱| 国产日韩欧美在线一区| 精品剧情v国产在线观看在线| 6080yy午夜一二三区久久| 欧美三区在线观看| 一本一本大道香蕉久在线精品| 99久久精品99国产精品| 国产成人av自拍| 日本精品裸体写真集在线观看 | 亚洲综合图片区| 一区二区视频在线| 日韩精品电影一区亚洲| 精品一区二区成人精品| 国产精品亚洲一区二区三区在线| 成人免费看黄yyy456| 91麻豆免费看片| 欧美日韩久久一区二区| 久久久久久久网| 国产精品毛片高清在线完整版| 国产精品福利一区二区三区| 日本一区二区三区在线观看| 一区二区三区在线播| 亚洲一区二区三区精品在线| 国产一区二区三区久久悠悠色av| 99久久99久久精品国产片果冻| 欧美一区二区不卡视频| 亚洲另类一区二区| 激情伊人五月天久久综合| 在线中文字幕一区二区| 精品日韩欧美在线| 一区二区久久久久| 国产a精品视频| 欧美亚洲动漫制服丝袜| 久久久蜜桃精品| 亚洲最色的网站| 99久久精品国产毛片| 国产三级精品视频| 奇米精品一区二区三区四区| 色综合咪咪久久| 国产精品毛片大码女人| 国产一区不卡精品| 欧美精品一区二区三区蜜臀| 麻豆成人久久精品二区三区小说| 欧美三级在线播放| 亚洲综合在线电影| 欧美体内she精高潮| 亚洲成人免费av| 欧美一卡2卡三卡4卡5免费| 日韩国产欧美三级| 亚洲精品在线观看视频| 国产精品一区二区久激情瑜伽| 亚洲精品在线观看网站| 成人福利在线看| 国产精品沙发午睡系列990531| 91年精品国产| 亚洲成av人片观看| xf在线a精品一区二区视频网站| 国内成+人亚洲+欧美+综合在线| 91亚洲男人天堂| 亚洲午夜一二三区视频| 欧美一级在线视频| 日产国产欧美视频一区精品| 欧美日韩亚洲综合一区二区三区 | 日本韩国一区二区三区视频| 精品久久久久香蕉网| 国产一区二区伦理| 亚洲精品高清视频在线观看| 欧美色爱综合网| 欧美日韩国产美| 蜜臀va亚洲va欧美va天堂| 久久久久久99久久久精品网站| 亚洲国产成人自拍| 日韩精品乱码av一区二区| 亚洲国产精品成人综合色在线婷婷 | 一区二区三区加勒比av| 精品久久人人做人人爽| 欧美久久一区二区| 国产成人精品影院| 日产国产欧美视频一区精品 | 国产毛片精品国产一区二区三区| 国产女主播在线一区二区| 在线免费观看成人短视频| 日韩高清欧美激情| 日产精品久久久久久久性色| 亚洲国产欧美日韩另类综合| 成人免费一区二区三区视频| 国产亚洲欧美中文| 国产欧美视频在线观看| 2020国产精品| 国产精品精品国产色婷婷| 久久99久久精品欧美| 久久99国产精品尤物| 久久66热偷产精品| 99综合影院在线| 色噜噜狠狠色综合欧洲selulu| 丁香桃色午夜亚洲一区二区三区| 国产精品中文字幕欧美| 久久精品国产99| 蜜臀av性久久久久蜜臀av麻豆| 亚洲a一区二区| 久久国产福利国产秒拍| 日本系列欧美系列| 国内精品免费**视频| 97久久精品人人爽人人爽蜜臀| 亚洲第四色夜色| 免费欧美高清视频| 专区另类欧美日韩| 丝瓜av网站精品一区二区| 伊人婷婷欧美激情| 亚洲成av人片在www色猫咪| 亚洲国产精品久久一线不卡| 亚洲综合精品自拍| 欧美日韩国产另类不卡| 欧美欧美午夜aⅴ在线观看| 欧美日韩电影一区| 久久久久亚洲综合| 亚洲精品伦理在线| 日韩欧美一区二区在线视频| 国产午夜一区二区三区| 亚洲少妇屁股交4| 国产精品中文字幕一区二区三区| 99久久精品国产一区二区三区| 在线观看欧美精品| 国产精品初高中害羞小美女文| 亚洲国产精品久久久久秋霞影院| 国产成人综合视频| 国产天堂亚洲国产碰碰| 日本v片在线高清不卡在线观看| 99r精品视频| 亚洲欧美色一区| 国产成人小视频| 中文字幕欧美激情| 国内精品国产成人国产三级粉色| 欧美一区二区福利视频| 婷婷国产在线综合| 91国偷自产一区二区使用方法| 日本一区二区成人在线| 精品一区二区三区的国产在线播放| 日韩欧美中文字幕制服| 亚洲一级二级三级在线免费观看| 99精品视频一区| 午夜视频在线观看一区| 337p亚洲精品色噜噜狠狠| 亚洲成av人片在线| 欧美男生操女生| 极品少妇xxxx偷拍精品少妇| 精品999久久久| 欧美在线观看视频一区二区三区| 三级久久三级久久久| 国产欧美日韩亚州综合| 色综合久久综合网97色综合| 免费观看成人av|