mybatis查询返回map的问题

背景

假设背景:
想获取某个省下各个市有多少问题,以
Map<String, Integer> 的形式返回,key 代表某个市的问题个数
数据库表为:

prov_code varchar  代表省的编码
city_code varchar  代表市的编码
problem varchar    代表拥有的某个问题

所以有一条该市的数据就说明该市多了一个问题,假设500为江苏省的编码,510位南京市的编码,520为苏州市的编码,数据为

500  510  问题1
500  510  问题2
500  510  问题3
500  520  问题1
500  520  问题3

正确返回的某个省下各个市有多少问题的map结果应为

510”:3,
“520”:2

看下以下几种写法

1、mybatis只返回单个map

mapper接口:

Map<String,Object> selectCount(String provCode);

mybatis的xml文件中:

<select id="selectCount" resultType="map">
    select city_code as "cityCode",
    count(*) as "count"
    from prov_code_count
    where prov_code = #{provCode}
    group by city_code
  </select>

此时会报错,期待的是一个map,但是得到的结果是两个map,为

”cityCode“:”南京","count":3
”cityCode“:”苏州","count":2

可见mybatis返回的map是只能返回一个的,遇到多的就会报错,会将select后面的字段的名称作为key,值作为value。可参考:https://www.codeleading.com/article/52893335081/

2、查询返回map的list

这是第一个正确写法。
想要获取想要的效果,mybatis返回的是一个list的map,每个map同上一个结果,但是是list形式的

[
{”cityCode“:”南京","count":3},
{”cityCode“:”苏州","count":2}
]

mapper接口:

List<Map<String,Object>> selectCount(String provCode);

xml文件:

<select id="selectCount" resultType="map">
    select city_code as "cityCode",
    count(*) as "count"
    from prov_code_count
    where prov_code = #{provCode}
    group by city_code
  </select>

service层:

Map<String, Integer> branch2Count = toBranch2Count(mapper.selectCount(provCode);
private Map<String, Integer> toBranch2Count(List<Map<String, Object>> resMapList) {
        if (CollectionUtils.isEmpty(resMapList)) {
            return Collections.emptyMap();
        }

        Map<String, Integer> branch2Count = new HashMap<>(resMapList.size());
        resMapList.forEach(
                item -> {
                    branch2Count.put(String.valueOf(item.get("cityCode")), Integer.parseInt(String.valueOf(item.get("count"))));
                }
        );

        return branch2Count;
    }

可以看出这种方式mapper是返回的list形式的map,然后再在service层转换成所需的map的形式。

3、利用mybatis的@MapKey注解返回map

要先定义一个do对象,利用mybatis的@MapKey注解
do对象,分别为城市的编码,和该城市的问题的数量

Branch2CountDO.java
private String branchCode;
private Integer count;

mapper接口:

@MapKey("branchCode")
Map<String,Branch2CountDO> selectCount(String provCode);

xml文件:
先定义resultmap,再写sql

<resultMap id="result1" type="xxx.Branch2CountDO">
    <result column="city_code" property="branchCode"/>
    <result column="count" property="count"/>
</resultMap>

<select id="selectCount" resultMap="result1">
    select city_code , count(*) as "count"
    from prov_code_count where prov_code = #{provCode}
    group by city_code
</select>

service层:

Map<String, Branch2CountDO> res = mapper.selectCount(provCode);
Map<String, Integer> branch2Count = res.keySet().stream().collect(Collectors.toMap(branchCode -> branchCode, branchCode -> res.get(branchCode).getCount())

4、重写handler

参考:https://blog.csdn.net/sou_liu/article/details/47755635

  • 14
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: MyBatis 可以返回 Map 类型的结果,其中键(Key)为列名,值(Value)为对应的数据行中的值。返回 Map 的方法有两种方式: 1. 返回单个 Map 类型的结果 ```java Map<String, Object> resultMap = sqlSession.selectOne("selectUserById", 1); ``` 其中,`selectOne` 方法返回单个结果,`selectUserById` 是 SQL 映射文件中定义的查询语句的 ID,1 是查询参数。 2. 返回多个 Map 类型的结果 ```java List<Map<String, Object>> resultList = sqlSession.selectList("selectAllUsers"); ``` 其中,`selectList` 方法返回多个结果,`selectAllUsers` 是 SQL 映射文件中定义的查询语句的 ID。 无论是返回单个还是多个 Map 类型的结果,MyBatis 都会将查询结果映射到 Map 对象中,其中键为列名,值为对应的数据行中的值。 ### 回答2: MyBatis是一种常用的Java持久化框架,可以用于通过SQL语句与数据库进行交互。当你使用MyBatis查询数据库时,有时需要返回一个Map对象来保存查询结果。 MyBatis提供了多种返回结果类型,其中返回Map对象是一种常见的选择。你可以通过配置来告诉MyBatis使用Map作为返回结果类型,并指定Map的键和值。 首先,在MyBatis的映射文件(Mapper XML)中,你需要为你的查询语句配置使用Map返回结果。在select标签的resultType属性中,可以指定一个Map类型的别名或全限定名,表示使用Map作为返回结果。例如: ``` <select id="getUserInfo" resultType="java.util.Map"> SELECT * FROM users WHERE id = #{id} </select> ``` 上述代码表示使用java.util.Map作为查询结果的返回类型。 然后,在应用程序的代码中调用相应的查询方法。当MyBatis执行查询并获取结果时,它将把查询结果映射到一个Map对象中,其中键为列名,值为对应的数据值。 例如,如果查询结果有两列,分别是"id"和"name",那么返回Map对象将包含两个键值对,如下所示: ```java Map<String, Object> resultMap = sqlSession.selectOne("getUserInfo", 1); System.out.println(resultMap.get("id")); // 输出查询结果中的id值 System.out.println(resultMap.get("name")); // 输出查询结果中的name值 ``` 通过上述代码,你可以根据列名获取查询结果的值。 总结来说,MyBatis可以返回Map对象作为查询结果,你需要在映射文件中配置使用Map类型,并在代码中获取Map对象后根据键名获取对应的值。这样可以灵活地处理查询结果,并方便地进行数据操作。 ### 回答3: MyBatis是一个流行的Java持久化框架,可以与关系数据库进行交互。在MyBatis中,可以使用多种方式来返回查询结果,其中一种常用的方式是返回Map对象。 返回Map的操作步骤如下: 1. 首先,在MyBatis的映射文件中,编写SQL语句,并使用ResultMap来映射查询结果。可以使用resultType属性来指定返回结果的类型为Map。 2. 在Java代码中,通过调用MyBatis提供的查询方法来执行SQL语句,获取查询结果。 3. 当查询结果返回时,MyBatis会根据ResultMap的定义,将查询结果映射到一个Map对象中。 4. 可以通过调用Map的get()方法,根据指定的键获取相应的值。 使用返回Map的好处是可以方便地获取查询结果中的字段值,因为Map是一个键值对集合,可以通过键来获取对应的值。同时,返回Map还可以保留查询结果中的字段名与字段值之间的映射关系。 需要注意的是,当查询结果中存在多行记录时,返回Map对象会包含多个键值对,可以通过遍历Map对象,获取每行记录的字段值。 总之,MyBatis提供了返回Map的功能,可以方便地获取查询结果的字段值,并保留字段名与字段值之间的映射关系。这是MyBatis灵活性的体现之一。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值