Mybatis查询返回Map<String,Object>类型的实现

 更新时间:2023年07月24日 10:18:58   作者:保加利亚的风  
本文主要介绍了Mybatis查询返回Map<String,Object>类型的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

这篇我们来说一下Mybatis的查询结果返回Map类型。

首先我们在企业开发中是很少使用到Map返回类型的,很多都是直接返回一个对象实体。尤其是苞米豆出了MP框架之后,XML都是很少写的。

那么在什么情况下需要使用Map来作为返回的结果类型呢?

案例:有一个模块A和模块B,A模块的POM依赖引入了B模块,A模块可以直接使用B模块的实体,但是B模块使用不到A模块的实体,如果在B模块POM中引入A模块的依赖,那么在运行时会出现依赖循环错误,这时候就需要自己写SQL来返回Map类型了,因为返回不了另一个实体,所以需要定义 Map集合来返回

第一种:返回值为Map<string,Object>类型,但是只能接收一条数据,数据超过一条会报错。如下

第二种:List<Map<String,Object>>类型,返回的是一个集合,可以接收多条数据。这种场景用的最多的还是连接查询。由于在mybatis查询返回结果时如果设计到两个表,需要在xml中配置association或者collection或者其他多种方式,但都过于麻烦,所以我们可以使用这种方式来接收返回的数据。

第三种:Map<String,Map<String,Object>>类型,返回的是一个KV,DAO层需要添加@MapKey注解,K为注解的值(注解上的值表示数据库某字段,字段必须保证唯一,例如主键或唯一索引的字段),V代表查询出来的数据

我们首先演示一下

第一种:Map<String,Object>类型

package com.ywt.springboot.mapper;
import java.util.Map;
/**
 * @author pc
 */
public interface StudentMapper {
    //查询所有的学生
    Map<String,Object> findDataToMap(Integer id);
}

Mapper.xml

测试一下

第二种List<Map<String,Object>>

单表查询返回多条数据

Mapper层

Mapper.xml

测试一下

多表查询返回多条数据

Mapper:

@MapKey(value = "id")
List<Map<String, Object>> queryList();

XML:

<select id="queryList" resultType="java.util.Map">
        select s.*, t.t_name, t.t_id
        from student s
        left join teacher t on s.id = t.s_id
</select>

测试结果:

<==    Columns: id, name, age, phone, address, t_name, t_id
<==        Row: 1, 蔡徐坤, 18, 111, 浙江温州, 李四, 2
<==        Row: 1, 蔡徐坤, 18, 111, 浙江温州, 张三, 1
<==        Row: 2, 五一烦, 20, 333, 派出所, 王五, 3
<==      Total: 3
[{t_id=2, address=浙江温州, phone=111, t_name=李四, name=蔡徐坤, id=1, age=18}, {t_id=1, address=浙江温州, phone=111, t_name=张三, name=蔡徐坤, id=1, age=18}, {t_id=3, address=派出所, phone=333, t_name=王五, name=五一烦, id=2, age=20}]

第三种:Map<String, Map<String,Object> >

Mapper层

Mapper.xml

测试结果

到此这篇关于Mybatis查询返回Map<String,Object>类型的实现的文章就介绍到这了,更多相关Mybatis查询返回Map<String,Object>内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • Java中的@Conditional条件注解详细解析

    Java中的@Conditional条件注解详细解析

    这篇文章主要介绍了Java中的@Conditional条件注解详细解析,@Conditional是Spring4新提供的注解,它的作用是按照一定的条件进行判断,满足条件给容器注册bean,需要的朋友可以参考下
    2023-11-11
  • Java中如何正确重写equals方法

    Java中如何正确重写equals方法

    Object类中equals方法比较的是两个对象的引用地址,只有对象的引用地址指向同一个地址时,才认为这两个地址是相等的,否则这两个对象就不相等
    2021-10-10
  • Java8 List集合如何移除满足条件的元素

    Java8 List集合如何移除满足条件的元素

    这篇文章主要介绍了Java8 List集合如何移除满足条件的元素,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • springboot3整合knife4j详细图文教程(swagger增强)

    springboot3整合knife4j详细图文教程(swagger增强)

    开发api提供对应的接口规范进行联调或并行开发,api文档管理必不可少,常用的Knife4j基于swagger(依赖已经compile),可以进行管理,下面这篇文章主要给大家介绍了关于springboot3整合knife4j的相关资料,需要的朋友可以参考下
    2024-03-03
  • JAVA中JSONObject对象和Map对象之间的相互转换

    JAVA中JSONObject对象和Map对象之间的相互转换

    这篇文章主要介绍了JAVA中JSONObject对象和Map对象之间的相互转换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • Mybatis传参为逗号分隔的字符串情形进行in条件查询方式

    Mybatis传参为逗号分隔的字符串情形进行in条件查询方式

    这篇文章主要介绍了Mybatis传参为逗号分隔的字符串情形进行in条件查询方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • SpringBoot+Vue+JWT的前后端分离登录认证详细步骤

    SpringBoot+Vue+JWT的前后端分离登录认证详细步骤

    这篇文章主要介绍了SpringBoot+Vue+JWT的前后端分离登录认证,其实创建后端springboot工程也很简单,本文安装idea步骤一步步给大家详细介绍,需要的朋友可以参考下
    2021-09-09
  • 在SpringBoot项目中解决依赖冲突问题的方法

    在SpringBoot项目中解决依赖冲突问题的方法

    在SpringBoot项目中,依赖冲突是一个常见的问题,特别是当项目引入多个第三方库或框架时,依赖冲突可能导致编译错误、运行时异常或不可预测的行为,本文给大家介绍了如何在SpringBoot项目中解决以来冲突问题的方法,需要的朋友可以参考下
    2024-01-01
  • 详解FutureTask如何实现最大等待时间

    详解FutureTask如何实现最大等待时间

    这篇文章主要为大家详细介绍了如何从源码中了解FutureTask实现最大等待时间的方法,文中的示例代码讲解详细,感兴趣的可以了解一下
    2023-03-03
  • Mybatis中实体类属性与数据列表间映射方法介绍

    Mybatis中实体类属性与数据列表间映射方法介绍

    这篇文章主要介绍了Mybatis中实体类属性与数据列表间映射方法介绍,一共四中方法,供大家参考。
    2017-10-10

最新评论