plsql 处理异常并记录在表内

本文介绍了在数据库操作中使用存储过程或触发器进行异常处理,并详细说明了如何在异常发生时记录错误日志,包括日志表创建、异常捕获、日志插入与提交操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先创建日志表GATEWAY_DB_LOG

create table GATEWAY_DB_LOG
(
  GW_ID       NUMBER(38) not null,
  LOG_TIME    DATE not null,
  LOG_CONTENT VARCHAR2(500),
  LOG_TYPE    VARCHAR2(20),
  LOG_SRC     VARCHAR2(50)
)

 

在存储过程或触发器内最后加上:

 

EXCEPTION --异常处理
            WHEN OTHERS THEN
              BEGIN
                rollback;
                ERROR_MSG :=sqlerrm(sqlcode) || ' CODE:' || sqlcode;
                INSERT INTO GATEWAY_DB_LOG (LOG_TIME,LOG_CONTENT,LOG_TYPE,LOG_SRC)
                           VALUES (sysdate,ERROR_MSG,
                           'tmp_flight','BATCH_ADD_DYNAMIC_PLAN');
                commit ;          
              END;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值