百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

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

sinye56 2024-10-03 00:43 9 浏览 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。。。(共几十个)的负数,难怪报数字溢出的错。

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

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

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

相关推荐

Linux在线安装JDK1.8

首先在服务器pingwww.baidu.com查看是否可以连网然后就可以在线下载一、下载安装JDK1.81、在下载安装的同时做好一些准备工作...

Linux安装JDK,超详细

1、了解RPMRPM是Red-HatPackageManager(RPM软件包管理器)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux...

Linux安装jdk1.8(超级详细)

前言最近刚购买了一台阿里云的服务器准备要搭建一个网站,正好将网站的一个完整搭建过程分享给大家!#一、下载jdk1.8首先我们需要去下载linux版本的jdk1.8安装包,我们有两种方式去下载安装...

Linux系统安装JDK教程

下载jdk-8u151-linux-x64.tar.gz下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.ht...

干货|JDK下载安装与环境变量配置图文教程「超详细」

1.JDK介绍1.1什么是JDK?SUN公司提供了一套Java开发环境,简称JDK(JavaDevelopmentKit),它是整个Java的核心,其中包括Java编译器、Java运行工具、Jav...

Linux下安装jdk1.8

一、安装环境操作系统:CentOSLinuxrelease7.6.1810(Core)JDK版本:1.8二、安装步骤1.下载安装包...

Linux上安装JDK

以CentOS为例。检查是否已安装过jdk。yumlist--installed|grepjdk或者...

Linux系统的一些常用目录以及介绍

根目录(/):“/”目录也称为根目录,位于Linux文件系统目录结构的顶层。在很多系统中,“/”目录是系统中的唯一分区。如果还有其他分区,必须挂载到“/”目录下某个位置。整个目录结构呈树形结构,因此也...

Linux系统目录结构

一、系统目录结构几乎所有的计算机操作系统都是使用目录结构组织文件。具体来说就是在一个目录中存放子目录和文件,而在子目录中又会进一步存放子目录和文件,以此类推形成一个树状的文件结构,由于其结构很像一棵树...

Linux文件查找

在Linux下通常find不很常用的,因为速度慢(find是直接查找硬盘),通常我们都是先使用whereis或者是locate来检查,如果真的找不到了,才以find来搜寻。为什么...

嵌入式linux基本操作之查找文件

对于很多初学者来说都习惯用windows操作系统,对于这个系统来说查找一个文件简直不在话下。而学习嵌入式开发行业之后,发现所用到的是嵌入式Linux操作系统,本想着跟windows类似,结果在操作的时...

linux系统查看软件安装目录的方法

linux系统下怎么查看软件安装的目录?方法1:whereis软件名以查询nginx为例子...

Linux下如何对目录中的文件进行统计

统计目录中的文件数量...

Linux常见文件目录管理命令

touch用于创建空白文件touch文件名称mkdir用于创建空白目录还可以通过参数-p创建递归的目录...

Linux常用查找文件方法总结

一、前言Linux系统提供了多种查找文件的命令,而且每种查找命令都具有其独特的优势,下面详细总结一下常用的几个Linux查找命令。二、which命令查找类型:二进制文件;...

取消回复欢迎 发表评论: