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天前
|
存储 消息中间件 算法
Java中的集合框架详解:List、Set、Map的使用场景
Java中的集合框架详解:List、Set、Map的使用场景
|
10天前
|
Java Linux 测试技术
Java sdk连接fabric网络的谜之报错
Java sdk连接fabric网络的谜之报错
16 0
|
3天前
|
Java Shell Nacos
centos7.x使用nacos2.1.0(解决JAVA_HOME、javac报错)
centos7.x使用nacos2.1.0(解决JAVA_HOME、javac报错)
7 1
|
4天前
|
Java
Intellij idea 报错:Error : java 不支持发行版本5
Intellij idea 报错:Error : java 不支持发行版本5
8 0
|
4天前
使用字节输入流报错 java.io.FileNotFoundException: srcdruid.properties (系统找不到指定的文件。)
使用字节输入流报错 java.io.FileNotFoundException: srcdruid.properties (系统找不到指定的文件。)
8 0
|
3天前
|
Dart
Dart之集合详解(List、Set、Map)
Dart之集合详解(List、Set、Map)
9 1
|
8天前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
|
3天前
|
Go
go语言map、实现set
go语言map、实现set
10 0
|
3天前
|
存储 自然语言处理 C++
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
11 0
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
|
7天前
|
存储 算法 NoSQL
C++一分钟之-map与set容器详解
【6月更文挑战第21天】C++ STL的`map`和`set`是基于红黑树的关联容器,提供有序存储和高效查找。`map`存储键值对,键唯一,值可重复;`set`仅存储唯一键。两者操作时间复杂度为O(log n)。常见问题包括键的唯一性和迭代器稳定性。自定义比较函数可用于定制排序规则,内存管理需注意适时释放。理解和善用这些工具能提升代码效率。
13 3