解决IDEA报错:org.springframework.dao.InvalidDataAccessApiUsageException: Error attempting to get column

发现错误,及时改正,善莫大焉

今天来解决一个SpringBoot项目中的报错,以下是具体的报错信息:

org.springframework.dao.InvalidDataAccessApiUsageException: Error attempting to get column 'update_time' from result set.  Cause: java.sql.SQLFeatureNotSupportedException
; null; nested exception is java.sql.SQLFeatureNotSupportedException
	at org.springframework.jdbc.support.SQLExceptionSubclassTranslator.doTranslate(SQLExceptionSubclassTranslator.java:96)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79)
	at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:91)
	at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:441)
	at jdk.proxy2/jdk.proxy2.$Proxy84.selectList(Unknown Source)
	at org.mybatis.spring.SqlSessionTemplate.selectList(SqlSessionTemplate.java:224)
	at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.executeForIPage(MybatisMapperMethod.java:121)
	at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.execute(MybatisMapperMethod.java:85)
	at com.baomidou.mybatisplus.core.override.MybatisMapperProxy$PlainMethodInvoker.invoke(MybatisMapperProxy.java:148)
	at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89)
	at jdk.proxy2/jdk.proxy2.$Proxy111.selectVOPage(Unknown Source)
	at com.lzp.Service.Imp.NotificationServiceImpl.selectPage(NotificationServiceImpl.java:59)

问题分析:

这个项目中使用了MybatiPlus框架,之前运行一切都正常,但这次给项目多加了功能后就报错了

新加的功能对应的VO实体类中,为两个时间属性

我把项目中代码从头到尾检查了一遍没有问题后,我突发奇想就去Maven中分析依赖关系,看看是否是Maven这块出了问题。

经过一 一排除后,证明我思考的是对的,最终得出:

由于Druid数据源的版本太低,不支持JDK8中的LocalDate、LocalTime、LocalDateTime这些日期类型,而下载新版本的Druid依赖后,运行就正常了

解决方法:

使用1.1.21版本的Druid依赖即可解决

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.21</version>
</dependency>

补充:版本需要大于等于1.1.21以上的Druid包

至此希望能够给你带来帮助(#^.^#)