[Spring] [JPA] SQL Error: 1030, SQLState: HY000, Got error 12

在这里插入图片描述

欢迎加入 Spring cloud 交流群: 617143034

简介

本博客站点已全量迁移至 DevDengChao 的博客 https://blog.dengchao.fun , 后续的新内容将优先在自建博客站进行发布, 欢迎大家访问.

今天在合并微服务的过程中遇到了一个没遇到过的异常, 特此记录一下.

异常日志

SqlExceptionHelper   : SQL Error: 1030, SQLState: HY000
SqlExceptionHelper   : Got error 122 - 'Internal (unspecified) error in handler' from storage engine

异常抛出点

Caused by: java.sql.SQLException: Got error 122 - 'Internal (unspecified) error in handler' from storage engine
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129)
	at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
	at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122)
	at com.mysql.cj.jdbc.ClientPreparedStatement.executeInternal(ClientPreparedStatement.java:953)
	at com.mysql.cj.jdbc.ClientPreparedStatement.executeQuery(ClientPreparedStatement.java:1003)
	at com.zaxxer.hikari.pool.ProxyPreparedStatement.executeQuery(ProxyPreparedStatement.java:52)
	at com.zaxxer.hikari.pool.HikariProxyPreparedStatement.executeQuery(HikariProxyPreparedStatement.java)

解决方案

网上有许多帖子提到了 MySQL 缓存方面的问题, 查询云数据库的监控后对这个推断表示怀疑.
由于合并前后的微服务使用的是同一台数据库进行测试的, 因此只需要检出合并前的代码, 再运行一次完整的测试, 就可以确认不是由于缓存造成的问题了.

后来将运行时的 sql 打印出来, 发现是由于合并前后字段的命名方式不同引发的问题.
解决方案也很简单, 重新指定一下 @Colume 注解的 name 属性就行了.

推广

欢迎加入 Spring cloud 交流群: 617143034

欢迎大家使用 阿里云优惠券, 新购续费更优惠:
限量阿里云优惠券

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值