美文网首页
说一说 JPA + Oracle 项目启动时遇到一大坑,你碰到过

说一说 JPA + Oracle 项目启动时遇到一大坑,你碰到过

作者: 技术指北 | 来源:发表于2021-07-23 23:19 被阅读0次

    简述

    本文讲述的问题,是基于spring boot + spring data Jpa + Oracle 作为主要技术组合的项目;我们都知道,Jpa其实就是封装了hibernate,所以在实体类这块,跟原生hibernate的做法是一样的,只不过对接上了spring boot,就用上了许多注解,比如绑定表用@Table、@Entity,属性@Column,主键@Id 等等,此文暂且就不一一列举了;下面直接晒出此次坑点的日志。

    坑点日志

    2021-07-20 10:30:29.201 ERROR 6380 --- [           main] o.h.e.j.e.internal.JdbcEnvironmentImpl   : Could not fetch the SequenceInformation from the database
    
    java.sql.SQLException: 数字溢出
     at oracle.jdbc.driver.NumberCommonAccessor.throwOverflow(NumberCommonAccessor.java:4170) ~[ojdbc7-12.1.0.2.jar:12.1.0.2.0]
     at oracle.jdbc.driver.NumberCommonAccessor.getLong(NumberCommonAccessor.java:638) ~[ojdbc7-12.1.0.2.jar:12.1.0.2.0]
     at oracle.jdbc.driver.GeneratedStatement.getLong(GeneratedStatement.java:228) ~[ojdbc7-12.1.0.2.jar:12.1.0.2.0]
     at oracle.jdbc.driver.GeneratedScrollableResultSet.getLong(GeneratedScrollableResultSet.java:620) ~[ojdbc7-12.1.0.2.jar:12.1.0.2.0]
     at oracle.jdbc.driver.GeneratedResultSet.getLong(GeneratedResultSet.java:1361) ~[ojdbc7-12.1.0.2.jar:12.1.0.2.0]
     at com.zaxxer.hikari.pool.HikariProxyResultSet.getLong(HikariProxyResultSet.java) ~[HikariCP-4.0.3.jar:na]
     at org.hibernate.tool.schema.extract.internal.SequenceInformationExtractorLegacyImpl.resultSetMinValue(SequenceInformationExtractorLegacyImpl.java:134) ~[hibernate-core-5.4.32.Final.jar:5.4.32.Final]
     at org.hibernate.tool.schema.extract.internal.SequenceInformationExtractorLegacyImpl.extractMetadata(SequenceInformationExtractorLegacyImpl.java:60) ~[hibernate-core-5.4.32.Final.jar:5.4.32.Final]
     at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentImpl.sequenceInformationList(JdbcEnvironmentImpl.java:403) [hibernate-core-5.4.32.Final.jar:5.4.32.Final]
    
    2021-07-20 10:30:31.592  WARN 6380 --- [           main] o.h.engine.jdbc.spi.SqlExceptionHelper   : SQL Error: 17026, SQLState: 99999
    2021-07-20 10:30:31.592 ERROR 6380 --- [           main] o.h.engine.jdbc.spi.SqlExceptionHelper   : 数字溢出
    2021-07-20 10:30:31.604 ERROR 6380 --- [           main] j.LocalContainerEntityManagerFactoryBean : Failed to initialize JPA EntityManagerFactory: 
    [PersistenceUnit: default] Unable to build Hibernate SessionFactory; nested exception is org.hibernate.exception.GenericJDBCException: Unable to build DatabaseInformation
    

    日志全文看如下图:

    日志全文

    注意看图中我画红线的地方;

    我们都知道,Oracle数据库有序列这么一回事,很多表的单主键,我们也会设置一个自增序列来生成主键的值;问题关键,怪就怪在,我的这个项目中,一个序列我都没有定义,但是启动项目,就报上面的这个错,起初我以为是某个数值型属性长度设置错了,就把全部数值型的属性都改为Long或者Double,但还是报这个错;

    回头再仔细看日志,发现有说到查询什么序列之类的字眼,于是去数据库查看当前用户下的序列情况,发现都很正常啊,没什么超长数值啊;

    没办法,最后根据日志暴露出的这些底层源码类去跟踪相应的方法,发现项目在初始化数据库相关信息的时候,回去查询整个数据库的所有序列,涵盖所有数据库用户的序列,我就去查询其他用户的序列,发现还真有几个序列的最小值被设置为-999。。。(共几十个9)的负数,难怪报数字溢出的错。

    最后,我与相关管理员探讨,修改这些序列后,我的项目终于正常启动了。

    仅在此记录一下我遇到的这个坑点,望各位道友以后能一眼辩出,下篇文章我再讲讲序列初始化的链路。

    好了,若觉得文章还不错,记得点赞评论转发哦!!!

    相关文章

      网友评论

          本文标题:说一说 JPA + Oracle 项目启动时遇到一大坑,你碰到过

          本文链接:https://www.haomeiwen.com/subject/dacmmltx.html