• 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 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文件的具体信息。

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

  • 相关阅读:
    C/C++ volatile
    Linux fopen/fread/fwrite和open/read/write
    反思 承认失败,负重前行。
    算法和数据结构 打印回形矩阵
    Linux 软链接和硬链接
    数据库 CAS原理和ABA问题
    算法和数据结构 海量数据求前K个数
    算法和数据结构 冒泡排序
    java中的经典算法之选择排序(SelectionSort)
    【Java】常量、关键字、标识符、注释
  • 原文地址:https://www.cnblogs.com/ocean-san/p/4074194.html
Copyright © 2020-2023  润新知