当前位置:网站首页>ORA-06512 数字或值错误字符串缓冲区太小
ORA-06512 数字或值错误字符串缓冲区太小
2022-08-03 09:18:00 【m0_67394230】
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:
- Fix the condition that is causing the unhandled error.
- Write anexception handlerfor this unhandled error.
- 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
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
猜你喜欢
随机推荐
mysqldump导出提示:mysqldump [Warning] Using a password on the command line interface can be insecure
批量将PNG格式转化为JPG格式
Index (3)
WinCheck Script
【字节面试】word2vector输出多少个类别
二叉查找树的综合应用
Flink Yarn Per Job - 启动AM
pytorch one-hot tips
015-Balanced binary tree (1)
【网络安全】Kail操作系统
【LeetCode】101.对称二叉树
【LeetCode】老虎证券面试-括号嵌套且满足优先级
深度学习之 10 卷积神经网络2
xtrabackup
MySQL-存储过程-函数-
Gauva的ListenableFuture
dflow入门4——recurse&reuse&conditional
scala减少,reduceLeft reduceRight,折叠,foldLeft foldRight
深度学习之 10 卷积神经网络1
MySQL8重置root账户密码图文教程