java报错Error attempting to get column ‘XXX’ from result set. Cause: java.sql.怎么解决?

简介: java报错Error attempting to get column ‘XXX’ from result set. Cause: java.sql.怎么解决?

b98a6553f7e149199b1e2fff97d5aacc.png

在写java的时候,各种问题层出不穷。特别是对于新手来说。 头一次写java 项目,遇到问题后就只能百度搜索查询。


java开发中不常碰到的问题,例如:


引入包的版本问题。

版本不兼容问题。

我们是没发一次性知道的。只有在做某些特定时期的时候才能知晓。

就比如,笔者也是一个java新手,头一次的java项目中就遇到了如下问题:


项目使用 SpringBoot + Mybatis-plus

用到了LocalDateTime 类型。

然而在转换时候报错


Error attempting to get column 'XXX' from result set. Cause: java.sql.


这时候我们的解题思路是什么呢?

既然是类型问题,我们就必须找找类型的事。


查看数据库中的时间字段,发现类型是:datetime。

而我们的实际项目中使用的则是 LocalDatetime类型。

当我们确定后再尝试,会发现导致查询报错的就是这个类型问题。


那么如何解决这个问题呢?


最简单的就是更换druid。也就是集成了druid数据源的问题。通过查看mybatis-plus更新文档得知。


mybatis-plus 3.1.1+ 版本

使用了新版的jdbc,LocalDateTime等日期类型处理方式给做了一定的升级、但是我们集成进来的druid在1.1.21版本之前不支持LocalDateTime。

58d1ce9ecee44733b144ed3184dcafaa.png


如上图所示,3.1.1版本之后做个升级处理

因此我们断定:

是因为com.alibaba 的版本问题。

解决方法:


  1. 切换版本号到1.1.22 即可消除问题
   <dependency>
         <groupId>com.alibaba</groupId>
         <artifactId>druid-spring-boot-starter</artifactId>
         <version>1.1.22</version>
   </dependency>

2.让mybatis-plus版本保持在3.1.0.


3.如果非要使用最新版本的mybatis-plus,我们就必须换掉druid数据源。采用spring boot 默认数据源。让它保持于mybatis-plus 的版本保持紧跟即可。

目录
相关文章
|
3月前
|
SQL 关系型数据库 MySQL
这样的SQL执行为什么不会报错?optimizer_trace深度历险
【10月更文挑战第12天】本文探讨了一条看似错误但实际上能成功执行的SQL语句,通过开启MySQL的优化器追踪功能,详细分析了SQL的执行过程,揭示了子查询被优化器解析为连接操作的原因,最终解释了为何该SQL不会报错。文章不仅增进了对SQL优化机制的理解,也展示了如何利用优化器追踪解决实际问题。
|
18天前
|
Java Maven Spring
【SpringBug】lombok插件失效,但是没有报错信息,@Data不能生成get和set方法
解决写了@Data注解,但是在测试文件中生成的反编译target文件Us二Info中没有get和set方法
145 15
|
2月前
|
Java Windows
IDEA不使用lombok,如何快速生成get和set方法
【11月更文挑战第10天】在 IntelliJ IDEA 中生成 `get` 和 `set` 方法有多种方式:通过菜单操作、使用快捷键或自定义模板。菜单操作包括选择“Code”菜单中的“Generate...”,快捷键为“Alt + Insert”。自定义模板可在“File”-&gt;“Settings”-&gt;“Editor”-&gt;“Code Style”-&gt;“Java”中设置。批量生成时,可多选变量一次性生成。
|
3月前
|
SQL 关系型数据库 MySQL
|
4月前
|
SQL 数据库
SQL error : “No query“问题参考
本文介绍了解决SQL中"No query"错误的步骤,包括错误提示、正确的SQL语句写法,以及更多相关参考信息。错误的原因是在构建更新语句时字段赋值之间缺少逗号,导致SQL解析失败。文章还提供了正确格式的SQL语句和相关错误处理的参考链接。
SQL error : “No query“问题参考
|
3月前
|
Java
让星星⭐月亮告诉你,Java NIO之Buffer详解 属性capacity/position/limit/mark 方法put(X)/get()/flip()/compact()/clear()
这段代码演示了Java NIO中`ByteBuffer`的基本操作,包括分配、写入、翻转、读取、压缩和清空缓冲区。通过示例展示了`position`、`limit`和`mark`属性的变化过程,帮助理解缓冲区的工作原理。
42 2
|
3月前
|
C#
SET访问器和GET访问器
SET访问器和GET访问器
41 2
|
3月前
|
小程序 Java
小程序通过get请求提交数据到java后台
小程序通过get请求提交数据到java后台
38 0
|
Java
java中Set,Map,Stack一些简单用法
1 import java.util.Iterator; 2 import java.util.Stack; 3 import java.io.*; 4 import java.util.
641 0