说一说 JPA + Oracle 项目启动时遇到一大坑,你碰到过吗?
csdh11 2025-05-21 13:04 9 浏览
简述
本文讲述的问题,是基于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。。。(共几十个)的负数,难怪报数字溢出的错。
最后,我与相关管理员探讨,修改这些序列后,我的项目终于正常启动了。
仅在此记录一下我遇到的这个坑点,望各位道友以后能一眼辩出,下篇文章我再讲讲序列初始化的链路。
好了,若觉得文章还不错,记得点赞评论转发哦!!!
- 上一篇:甲方提供核心jar包,添加到本地maven仓库
- 下一篇:Maven常用命令
相关推荐
- 跨越26年的宝可梦系列游戏你玩过几款?
-
作为一个宝可梦IP的忠实爱好者,是时时刻刻关注着宝可梦的影视及游戏方面,在22年2月也即将引来正统续作宝可梦阿尔宙斯(其实还是更习惯口袋妖怪的翻译)宝可梦从1996年诞生至今一共有多少正统系列,小编做...
- ndsi,肩键L键失灵,拆开看看能不能修
-
很久没有玩nds了,新买了个R4烧录卡是带64g的游戏来玩玩,发现肩键L失灵了,打开看看能不能挽救一下。之前后盖上是有痛贴的,没办法只能忍痛撕下来了,撕下来之后还真白啊,上保护贴是真有必要的。话不多说...
- R4卡使用方法!游戏介绍及常见问题!任天堂掌机通用
-
哈喽大家好!我是掌机百科!今天介绍下R4卡的使用方法及教程,DS,NDS,NDSL,NDSLL,NDSXL,NDSI.NDSILL,NDSIXL,3DS,3DSLL,3DSXL,2DS,NEW3DS...
- JavaScript简介:从概念、特点、组成和用法全面带你快速了解JS
-
“这里是云端源想IT,帮你轻松学IT”...
- FileBrowser 是一个优秀的基于 Web 的文件管理器
-
FileBrowser是一个基于网页的文件管理器,允许用户通过浏览器界面管理服务器上的文件和目录。它提供了一种简单直观的方式来执行文件操作,如上传、下载、删除、重命名和编辑文件,以及管理目录。以下是...
- BrowserTools MCP赋能Cursor IDE:基于上下文实现浏览器无缝控制
-
一、项目介绍BrowserToolsMCP是基于Anthropic的ModelContextProtocol(MCP)构建的浏览器交互工具,通过与CursorIDE等AI编辑器深度整合,实现...
- 正确复制、重写别人的代码,不算抄袭
-
我最近在一篇文章提到,工程师应该怎样避免使用大量的库、包以及其他依赖关系。我建议的另一种方案是,如果你没有达到重用第三方代码的阈值时,那么你就可以自己编写代码。...
- 它来了、全新的Vue3中文文档来了
-
Vue.js-渐进式JavaScript框架|Vue.jsPlayicon...
- “我们太乙变化大”——第一书记讲述贫困村变化
-
来源:江西日报-江西新闻客户端江西新闻客户端讯(江西日报记者唐燕)“2018年1月,组织安排我到太乙村开展帮扶工作。两年来,我亲眼目睹并亲身经历了群众生产生活发生的巨大变化。看到群众生活越来越幸福,我...
- 趋势科技杀软曝密码漏洞:允许远程代码执行
-
IT之家讯来自谷歌的安全研究员TavisOrmandy最近很忙。几周之前,他发现了AVG杀软扩展程序可以绕过Chrome商店中的审查机制,自动安装到用户的Chrome浏览器中,而且这个扩展还会泄露...
- Vue3安装使用方式详解
-
对于开发和学习任何一门新技术,新框架,最主要的还是能够运行起来,怎么运行起来,这才是最主要的。所以,我们来说一下Vue.js的安装方式。因为Vue.js的设计初始,就是一个渐进式的J...
- 设置 Cursor MCP 与 BrowserTools 服务
-
一、安装Chrome扩展打开Chrome网上应用店,搜索...
- 那些通用清除软件不曾注意的秘密
-
系统清理就像卫生检查前的大扫除,即使你使出吃奶的劲儿把一切可能的地方都打扫过,还会留下边边角角的遗漏。随着大家电脑安全意识的提高,越来越多的朋友开始关注自己的电脑安全,也知道安装360系列软件来"武装...
- SharpBrowser:用C#打造超快的个性化开源浏览器!
-
推荐一个基于.Net8和CefSharp开发的开源浏览器。项目简介SharpBrowser是一个用C#和CefSharp开发的全功能网页浏览器。它声称是最快的开源C#网页浏览器,渲...
- 一周热门
- 最近发表
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)
- dos 删除目录下所有子目录及文件 (36)