网站首页 > 技术文章 正文
简述
本文讲述的问题,是基于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。。。(共几十个)的负数,难怪报数字溢出的错。
最后,我与相关管理员探讨,修改这些序列后,我的项目终于正常启动了。
仅在此记录一下我遇到的这个坑点,望各位道友以后能一眼辩出,下篇文章我再讲讲序列初始化的链路。
好了,若觉得文章还不错,记得点赞评论转发哦!!!
猜你喜欢
- 2024-11-12 JDK9模块化知识和规则入门 jdk9 module
- 2024-11-12 如何有效开发Java 如何有效开发地理教材
- 2024-11-12 BI工具入门:如何做关系数据源的连接?
- 2024-11-12 对另外网段的渗透测试 对网络开展渗透性测试
- 2024-11-12 一些可以显著提高大型 Java 项目启动速度的尝试
- 2024-11-12 为什么Python通过Jar包的方式不能同时链接多个异构库?
- 2024-11-12 powerdesigner连接Oracle逆向生成pdm文件。
- 2024-11-12 「转」jar包冲突漏洞,同一份代码有的主机运行正常,有的失败
- 2024-11-12 openjdk编译缺jfxrt.jar的坑货 openjdk没有javac
- 2024-11-12 一文带你搞懂JDBC原理-详解JDBC连接数据库
你 发表评论:
欢迎- 614℃几个Oracle空值处理函数 oracle处理null值的函数
- 605℃Oracle分析函数之Lag和Lead()使用
- 594℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 591℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 585℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 579℃【数据统计分析】详解Oracle分组函数之CUBE
- 568℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 559℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- PageHelper - 最方便的 MyBatis 分页插件
- 面试二:pagehelper是怎么实现分页的,
- MyBatis如何实现分页查询?(mybatis-plus分页查询)
- SpringBoot 各种分页查询方式详解(全网最全)
- 如何在Linux上运行exe文件,怎么用linux运行windows软件
- 快速了解hive(快速了解美国50个州)
- Python 中的 pyodbc 库(pydbclib)
- Linux搭建Weblogic集群(linux weblogic部署项目步骤)
- 「DM专栏」DMDSC共享集群之部署(一)——共享存储配置
- 故障分析 | MySQL 派生表优化(mysql pipe)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)