码迷,mamicode.com
首页 > 其他好文 > 详细

ORA-01438错误的解决方法

时间:2014-11-04 19:25:08      阅读:623      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   color   java   for   sp   文件   数据   

问题:项目中突然在更新或者是插入数据的时候报ora01438这个错,知道是number类型精度不匹配,但是自己debug发现并没有出现具体的表和字段

 

现象:java.sql.BatchUpdateException: ORA-01438: 值大于为此列指定的允许精度

 

我自己解决的方法:

在dba权限用户操作

 

alter system set events=1438 trace name Errorstack forever,level 12;

 

查看trace文件

通过oracle的警告文件/home/oracle/app/diag/rdbms/orcl/orcl/trace/alert_orcl.log可以帮助你准确定位trace文件

Tue Nov 04 13:54:09 2014
Errors in file /home/oracle/app/diag/rdbms/orcl/orcl/trace/orcl_ora_28912.trc:
ORA-01438: 值大于为此列指定的允许精度

 

找到指定的/home/oracle/app/diag/rdbms/orcl/orcl/trace/orcl_ora_28912.trc文件

----- Error Stack Dump -----
ORA-01438: 值大于为此列指定的允许精度
----- Current SQL Statement for this session (sql_id=as315uv85ktcx) -----
insert into "test" values(280750000)

 

但是我的真实的环境中并不是简单的insert语句,这里只能看到具体的是那张表出错。但是具体的是那个字段和字段的值,我只能分析

项目中数据来源是不是超出number(p,s)的范围。

虽然解决了问题,但是麻烦。

 

自己主要解决不了的问题,在于只能简单的分析trace文件,而不能分析trace文件的具体信息。

如有大神看到,请不吝赐教。

 

ORA-01438错误的解决方法

标签:style   blog   io   color   java   for   sp   文件   数据   

原文地址:http://www.cnblogs.com/ocean-san/p/4074194.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!