如果方法的返回值是Map<String, Object>而不是List<Map<String, Object>> 则resultType 应该是什么类型
时间: 2023-10-14 07:08:54 浏览: 101
如果方法的返回值是 `Map<String, Object>`,则 `resultType` 应该是 `java.util.HashMap` 或者其它实现了 `java.util.Map` 接口的类。例如:
```xml
<select id="selectUser" resultType="java.util.HashMap">
select * from user where id = #{id}
</select>
```
相关问题
如果方法的返回值是Map<String, Object>而不是List<Map<String, Object>> 则resultType 应该是什么类型
如果方法的返回值是Map<String, Object>,则resultType应该是java.util.Map类型。示例配置如下:
```xml
<select id="selectMap" resultType="java.util.Map">
SELECT * FROM my_table
</select>
```
mybatisplus多表联查 xml中sql返回map 如何设置map中的key
在 MyBatis-Plus 中,多表联查返回 Map 的方式非常简单,只需要使用 `selectMaps` 方法即可。这个方法的返回值是一个 List<Map<String, Object>>,其中每个 Map 对象对应一条查询结果,Map 的 key 是列名,value 是对应的值。
如果你想自定义返回的 Map 的 key,可以在 SQL 语句中使用别名来指定。例如:
```xml
<select id="getUserAndRole" resultType="java.util.Map">
SELECT u.id as userId, u.username, r.id as roleId, r.role_name
FROM user u
LEFT JOIN user_role ur ON u.id = ur.user_id
LEFT JOIN role r ON ur.role_id = r.id
WHERE u.id = #{userId}
</select>
```
在这个例子中,我们使用了 `as` 关键字为每个列指定了别名,这样返回的 Map 对象中就会包含 `userId`、`username`、`roleId` 和 `role_name` 四个 key。
注意,这里的 `resultType` 必须设置为 `java.util.Map`,否则会抛出异常。
阅读全文