ora错误匹配java_ORA-01438错误的解决方法

问题:项目中突然在更新或者是插入数据的时候报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 2014Errors 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文件的具体信息。

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值