mybatis查询数据时,返回类型设置的map,然后出现这个错误java.lang.NoSuchMethodException: java.util.Map.<init>

解决办法

这个错误是因为 MyBatis 在将查询结果封装为 Map 类型时,尝试调用 Map 类的无参构造方法来创建一个新的 Map 实例,但是 Map 接口本身并没有定义无参构造方法,所以会抛出 NoSuchMethodException 异常。

要解决这个问题,可以尝试将返回类型改为 HashMap 或其他实现了 Map 接口的具体类型,如下所示:

@Select("SELECT * FROM my_table")
public List<HashMap<String, Object>> queryData();

或者在 SQL 映射文件中指定具体的返回类型,如下所示:

<select id="queryData" resultType="java.util.HashMap">
    SELECT * FROM my_table
</select>

posted @   JamieChyi  阅读(127)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示