请教各位高手 oracle 存储过程 如何将获得捕获异常的内容写入一张表里

请教各位高手oracle存储过程如何将获得捕获异常的内容写入一张表里例如DBMS_OUTPUT.PUT_LINE(SUBSTR(SQLERRM,1,200));将SUBS... 请教各位高手 oracle 存储过程 如何将获得捕获异常的内容写入一张表里
例如 DBMS_OUTPUT.PUT_LINE(SUBSTR(SQLERRM, 1, 200));
将SUBSTR(SQLERRM, 1, 200)写人
insert into t_log_error values('1','2','3',SUBSTR(SQLERRM, 1, 200),'%$%&',sysdate);
是不是没法实现啊。

create or replace procedure p_testone is
v number(2);

begin
select 1 / 0 into v from dual;
insert into t_log_error values('1','2','3',SUBSTR(SQLERRM, 1, 200),'%$%&',sysdate);
--异常处理
EXCEPTION WHEN OTHERS THEN ROLLBACK;
DBMS_OUTPUT.PUT_LINE(SUBSTR(SQLERRM, 1, 200));
end;
存储过程编译都没过去
展开
 我来答
cl_neu
推荐于2017-09-17 · 超过34用户采纳过TA的回答
知道答主
回答量:52
采纳率:0%
帮助的人:47.1万
展开全部
可以先定义个变量,发生异常的时候将异常信息赋值给变量,插入表的时候用变量,
日志表没给表结构,我自己重新定义了一个,测试ok。
CREATE TABLE T_LOG_ERROR
(ERR_ID NUMBER,
ERR_TIME DATE,
ERR_CODE NUMBER,
ERR_INFOR VARCHAR2(4000)
);

create or replace procedure p_testone is
v number(2);
v_sqlcode number;
v_sqlerrm varchar2(4000);
begin
select 1 / 0 into v from dual;

--异常处理
EXCEPTION WHEN OTHERS THEN
ROLLBACK;
v_sqlcode :=sqlcode;
v_sqlerrm :=SUBSTR(sqlerrm, 1, 2000);
insert into t_log_error values(1,sysdate,v_sqlcode,v_sqlerrm);
commit;
DBMS_OUTPUT.PUT_LINE(SUBSTR(SQLERRM, 1, 200));
end;

执行存储过程后就可以把异常信息记录到表t_log_error了。
丿弑丶九天灬0f02d82
2019-01-31 · TA获得超过148个赞
知道答主
回答量:41
采纳率:0%
帮助的人:2.4万
展开全部
总结起来你的问题就是在sqlerrm这个内置函数上,它应该被变量赋值,这样才能使用,SQL语句中,不能直接使用,sqlerrm,SQLcode这种
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式