龙空技术网

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

变速不变道 167

前言:

目前你们对“oracle数据库溢出”大约比较关心,你们都想要分析一些“oracle数据库溢出”的相关文章。那么小编在网摘上搜集了一些关于“oracle数据库溢出””的相关知识,希望大家能喜欢,姐妹们快快来了解一下吧!

简述

本文讲述的问题,是基于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 databasejava.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: 999992021-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。。。(共几十个)的负数,难怪报数字溢出的错。

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

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

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

标签: #oracle数据库溢出 #oraclejpa主键 #hibernateoracle建表