首页 > 代码库 > ORA-01438错误的解决方法
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文件的具体信息。
如有大神看到,请不吝赐教。
ORA-01438错误的解决方法
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。