iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >ORA-06512数字或值错误字符串缓冲区太小异常详解
  • 336
分享到

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

摘要

ORA-06512 网上最容易查到的解释为 CauseThis error is caused by the stack being unwound by unhandled exceptions in your PLs

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 an exception handler for 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

总结

到此这篇关于ORA-06512数字或值错误字符串缓冲区太小异常的文章就介绍到这了,更多相关ORA-06512数字或值错误字符串缓冲区太小内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: ORA-06512数字或值错误字符串缓冲区太小异常详解

本文链接: https://www.lsjlt.com/news/177600.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作