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.youkuaiyun.com/sou_liu/article/details/47755635

### 回答1: Mybatis是一种流行的Java ORM框架,它提供了几种查询结果返回类型,其中之一就是MapMybatis查询返回Map的方式可以通过在SQL映射文件中使用resultType属性指定为Map来实现。通常,我们可以使用类似于以下示例代码的方式: <select id="selectUser" resultType="map"> select * from user where id=#{id} </select> 当我们执行此查询时,Mybatis返回一个包含查询结果数据的Map对象。在这个Map对象中,键是列名,值是对应的列的值。 我们可以通过以下代码将查询结果转换为Map对象: Map<String, Object> result = sqlSession.selectOne("selectUser", 1); 在这个例子中,我们将查询结果转化为一个包含键和值的Map对象。这个Map对象的键是每个列的名称,值是对应的行数据。这样,我们就可以通过这个Map对象来实现数据的操作。 总的来说,Mybatis查询返回Map是一种非常方便的方式,可以通过映射文件中的简单指定来实现。然后,我们可以通过处理这些Map对象来实现复杂的数据操作。 ### 回答2: Mybatis查询返回`Map`是一种常见的数据返回方式,它将查询结果以`Map`的形式返回,以便于快速访问和操作。在使用Mybatis进行查询时,我们可以通过以下步骤返回`Map`对象: 1.在Mapper.xml中编写SQL语句,并选取返回值类型为`Map` ``` <select id="selectUser" parameterType="int" resultType="java.util.Map"> select * from user where id = #{id} </select> ``` 2.在Java代码中执行查询,并获取返回Map对象 ``` SqlSession sqlSession = sqlSessionFactory.openSession(); Map<String, Object> userMap = sqlSession.selectOne("selectUser", 1); ``` 在返回的`Map`中,键值对的形式为列名和对应的值,我们可以根据需要获取相应的值。例如,获取用户的名字和年龄可以这样写: ``` String name = (String)userMap.get("name"); int age = (int)userMap.get("age"); ``` 需要注意的是,当查询结果含有多条记录时,返回的`Map`对象只包含第一条记录的数据。此时需要使用`selectList`方法返回一个`List<Map>`来获取所有记录的数据。同时,在查询结果中,如果存在名字相同的列,Mybatis会自动将后面的列值覆盖前面的列值,因此建议在查询时尽量避免列名重复。 总而言之,Mybatis查询返回`Map`是一种方便快捷的数据返回方式,在需要快速获取数据时特别适用。但需要根据实际情况来判断是否适合使用,并注意使用过程中的一些细节。 ### 回答3: MyBatis 是一个流行的 ORM(对象关系映射)框架,用于简化数据库访问。MyBatis 查询返回 Map 是一种常见的查询结果格式,其主要优势在于可以根据查询结果的键名来访问对应的数据值。 在 MyBatis 中,我们可以使用 @MapKey 注解将查询结果转换为 Map。这个注解可以用于指定 Map 的键名,例如: ```java @MapKey("id") List<Map<String, Object>> selectUsersById(List<Integer> ids); ``` 这个示例中,我们使用 @MapKey 注解将查询结果转换为一个 Map,其中键名为 id,值为对应的 Map 对象。这样,我们就可以通过键名 id 来快速访问对应的用户信息。 当然,我们也可以使用自定义的键名。例如: ```java @MapKey("userName") List<Map<String, Object>> selectAllUsers(); ``` 这个示例中,我们将查询结果转换为一个 Map,其中键名为 userName,值为对应的 Map 对象。这样,我们就可以根据用户名来快速访问对应的用户信息。 除了使用 @MapKey 注解,我们还可以使用 ResultMap 自定义查询结果映射。例如: ```xml <resultMap id="userMap" type="java.util.HashMap"> <id column="id" property="id"/> <result column="user_name" property="userName"/> <result column="email" property="email"/> </resultMap> <select id="selectAllUsers" resultMap="userMap"> select id, user_name, email from users </select> ``` 这个示例中,我们定义了一个 resultMap,将查询结果映射为一个 HashMap。通过 column 和 property 属性可以指定键名和值的映射关系。 总的来说,MyBatis 查询返回 Map 是一种非常实用的查询结果格式,可以方便快捷地访问查询结果。同时,我们也可以通过 @MapKey 和 ResultMap 来自定义键名和值的映射关系,使查询结果更加灵活。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值