springboot JPA 实现jpql查询时报错:org.springframework.core.convert.ConverterNotFoundException 解决方案

在接口中写入jpql语句想要查询表中的特定字段,接口中的代码如下:

    @Query("select unitName, createTime, status, serviceCount, averageEval from UnitDetail")
    List<UnitDetail> loadUnitDetailList();

使用postman测试时,存在错误信息如下:
·org.springframework.core.convert.ConversionFailedException: Failed to convert from type [java.lang.Object[]] to type [@org.springframework.data.jpa.repository.Query com.remotegov.pojo.UnitDetail] for value '{1, 2021-07-08 16:28:12.0, 0, 1, 1}'; nested exception is org.springframework.core.convert.ConverterNotFoundException: No converter found capable of converting from type [java.lang.String] to type [@org.springframework.data.jpa.repository.Query com.remotegov.pojo.UnitDetail]

原因:
查询结果集封装到了Object[ ]中,并没有直接封装到unitDetail对象中,直接接收的话会产生转换异常。

解决方案:
方案1、将存储结果集的数组对象转换为Object[ ]类型;
方案2、由于Object[ ]类型操作不便,可以封装到实体类中,代码实现如下:
① 将字段值封装到对象中

    @Query("select new UnitDetail (unitName, createTime, status, serviceCount, averageEval) from UnitDetail")
    List<UnitDetail> loadUnitDetailList();

② 在实体类中添加字段对应的构造器

    public UnitDetail(String unitName, Date createTime, String status, String serviceCount, String averageEval) {
        this.unitName = unitName;
        this.createTime = createTime;
        this.status = status;
        this.serviceCount = serviceCount;
        this.averageEval = averageEval;
    }

运行后如下图,操作成功!
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Caused by: org.springframework.beans.factory.CannotLoadBeanClassException是一个由Spring框架引起的异常,它表示在加载bean类无法找到对应的类。 通常情况下,这个异常可能是由以下几个原因引起的: 1. 类路径配置错误:在配置文件(比如springmvc-config.xml)中指定的bean类的类路径不正确,导致无法加载该类。解决方法可以是检查类路径配置是否正确,确保指定的类存在于指定的位置。 2. 缺少依赖:如果bean类依赖于其他的类,而这些类没有正确地被导入或配置到项目中,就会导致无法加载bean类。解决方法可以是检查项目依赖是否正确配置,并确保所有依赖的类都存在于项目中。 3. 编译错误:如果bean类对应的源代码无法成功编译成class文件,也会导致无法加载bean类。解决方法可以是检查代码是否存在语法错误或逻辑错误,并确保代码正确编译。 4. 类文件丢失:如果bean类对应的class文件在部署环境中丢失或被删除,就会导致无法加载bean类。解决方法可以是重新部署或恢复缺失的class文件。 为了解决Caused by: org.springframework.beans.factory.CannotLoadBeanClassException异常,你可以尝试以下方法: 1. 检查类路径配置是否正确,确保指定的bean类存在于指定的位置。可以检查springmvc-config.xml文件中定义的bean的class属性,确保路径正确。 2. 确认项目的依赖是否正确配置,确保所有依赖的类都存在于项目中。可以检查项目的pom.xml文件或者相关的依赖配置文件,确保依赖的jar包已经正确引入项目。 3. 检查代码是否存在编译错误,确保代码正确编译。可以使用IDE的编译功能或者命令行编译项目,查看是否有任何编译错误。 4. 如果类文件丢失,可以尝试重新部署或恢复缺失的class文件。 通过以上方法,您应该能够解决Caused by: org.springframework.beans.factory.CannotLoadBeanClassException异常。如果问题仍然存在,您可以进一步调查具体的异常信息,以便更好地定位和解决问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [解决SpringDataJPA报错org.hibernate.HibernateException: Access to DialectResolutionInfo cannot be ...](https://download.csdn.net/download/weixin_38551749/14911017)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Spring项目启动报错org.springframework.beans.factory.CannotLoadBeanClassException: Cannot find classs...](https://blog.csdn.net/Denglishang/article/details/83152972)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值