ORA-06512 数字或值错误字符串缓冲区太小

ORA-06512 网上最容易查到的解释为

Cause

This error is caused by the stack being unwound by unhandled exceptions in your PLSQL code.

The options to resolve this Oracle error are:

  1. Fix the condition that is causing the unhandled error.
  2. Write an exception handler for this unhandled error.
  3. Contact your DBA for help.

The ORA-06512 error message indicates the line number of the unhandled error in the PLSQL code. This is quite useful when troubleshooting.

举个栗子来了解此异常

创建存储过程TestProc,参数v_number是一个长度为2的数字, 存储过程中将100赋值给v_number,执行存储过程后提示异常,ORA-06502表示发生的错误;ORA-06512表示发生的行数,本例中 因为100的是3位数字, v_number只能处理2位数字

SQL> CREATE OR REPLACE PROCEDURE TestProc AS
  2    v_number number(2);
  3  BEGIN
  4    v_number := 100;
  5  END;
  6  /
 
Procedure created
 
SQL> execute TestProc();
 
begin TestProc(); end;
 
ORA-06502: PL/SQL: 数字或值错误 : number precision too large
ORA-06512: 在 "BOSS643.TESTPROC", line 4
ORA-06512: 在 line 2

 针对上述问题,可以重新定义数值长度解决这个问题, v_number定义为3

SQL> CREATE OR REPLACE PROCEDURE TestProc AS
  2    v_number number(3);
  3  BEGIN
  4    v_number := 100;
  5  END;
  6  /
 
Procedure created
 
SQL> execute TestProc();
 
PL/SQL procedure successfully completed
 
SQL> 

如果将数值型修改成其他类型后也是同样的, 例如字符串,v_str设置为处理长度为10的字符串, 当给v_str赋值大于长度10的字符串后, 提示数字或者值错误,符串缓冲区太小

SQL> CREATE OR REPLACE PROCEDURE TestProc2 AS
  2    v_str varchar2(10);
  3  BEGIN
  4    v_str := 'This is a test string';
  5  END;
  6  /
 
Procedure created
 
SQL> execute TestProc2();
 
begin TestProc2(); end;
 
ORA-06502: PL/SQL: 数字或值错误 : character string buffer too small
ORA-06512: 在 "BOSS643.TESTPROC2", line 4
ORA-06512: 在 line 2

重新定义varchar2长度

SQL> CREATE OR REPLACE PROCEDURE TestProc2 AS
  2    v_str varchar2(512);
  3  BEGIN
  4    v_str := 'This is a test string';
  5  END;
  6  /
 
Procedure created
 

SQL> execute TestProc2();
 
PL/SQL procedure successfully completed
 
SQL> 

当然你也可以自定义异常来处理,例如当出现异常后提示“数值越界” ,此方法将异常捕获提示更加明确,个人认为ORA-06502异常已经十分清楚了, 具体还看存储过程对应的需求是否有明确提示需求

SQL> CREATE OR REPLACE PROCEDURE TestProc AS
  2    v_number number(2);
  3  BEGIN
  4    v_number := 100;
  5  EXCEPTION
  6    WHEN OTHERS THEN
  7      RAISE_APPLICATION_ERROR(-20001, '数值v_number越界');
  8  END;
  9  /
 
Procedure created
 
SQL> exec TestProc();
 
begin TestProc(); end;
 
ORA-20001: 数值v_number越界
ORA-06512: 在 "BOSS643.TESTPROC", line 7
ORA-06512: 在 line 2

相关资源:

Oracle Database Documentation - Oracle Database

PL/SQL User's Guide and Reference -- Contents

  

上一篇:Oracle 通过ODBC将Excel数据导入Oracle数据库

  • 7
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

=PNZ=BeijingL

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值