您的位置:首页技术文章
文章详情页

java - Mybatis 参数类型问题,应该是Map,结果报错.

【字号: 日期:2024-01-18 17:17:23浏览:64作者:猪猪

问题描述

我写了个查询接口,传入的参数是个Map,写SQL的时候,我在parameterType填写java.util.Map,调用居然报错,类型转换错误,String转map失败.我把parameterType改为String就没报错,结果出来了,但是我传入的是2个值啊!!!!!真崩溃~!代码如下:接口:

java - Mybatis 参数类型问题,应该是Map,结果报错.

报错的XML:

java - Mybatis 参数类型问题,应该是Map,结果报错.

修改为这样就正常了:

java - Mybatis 参数类型问题,应该是Map,结果报错.

但是我SQL里是多个参数啊,不应该用Map么???求大神解答疑惑

问题解答

回答1:

你的map 是null 你可以把错误贴出来

回答2:

因为你没在 mapper interface 的 method 里指定 @Param 注解,当此时只有一个参数的时候,会自动拆开。Map 类型会按 <String, Object> 拆开。复杂数据类型会根据 getter 拆开。

你可以参考一下这个:https://my.oschina.net/triday... 。

回答3:

你在接口里面指定一下Map的key value

回答4:

可能是接口的Map没有指定类型的问题,建议做一下修改:

public Module selectByMap(Map<String, Object> map)回答5:

楼主,我现在遇到跟你一样的问题,按照你的评论回复中的说法,mapper文件里面参数类型改为hashMap,DAO层不用任何注解,sql语句中取值语法跟你一样,但是仍未取到值,求解

标签: java