牛骨文教育服务平台(让学习变的简单)
博文笔记

Caused by: java.sql.BatchUpdateException: ORA-01438: 值大于为此列指定的允许精度如何解决

创建时间:2016-07-22 投稿人: 浏览次数:6505

Caused by: java.sql.BatchUpdateException: ORA-01438: 值大于为此列指定的允许精度
遇到这个问题时,从以下几点找原因
1.检查列所对应的实体的类型是否写错。
2.由于我用Oracle,主键是自增长,检查自增长的配置。若是用注解写的。看看有木有写错。

@Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "generator")    
    @SequenceGenerator(name = "generator",sequenceName="SEQ_USER")

    public Integer getId() {
        return this.id;
    }

以上没有问题。
3.检查数据库自增长的设置。
这里写图片描述
注意到id是number(4),之前从1000开始,改小一点就好了。

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。