Mybatis查询返回Map类型实例详解

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

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

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

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

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

如下

Mybatis查询返回Map<String,Object>类型实例详解_第1张图片

第二种:List>类型,返回的是一个集合,可以接收多条数据

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

我们首先演示一下第一种:Map类型

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

Mapper.xml

测试一下

Mybatis查询返回Map<String,Object>类型实例详解_第2张图片

第二种List>

 Mapper层

Mybatis查询返回Map<String,Object>类型实例详解_第3张图片

 Mapper.xml

Mybatis查询返回Map<String,Object>类型实例详解_第4张图片

 测试一下

Mybatis查询返回Map<String,Object>类型实例详解_第5张图片

 第三种:Map >

Mapper层

Mybatis查询返回Map<String,Object>类型实例详解_第6张图片

 Mapper.xml

Mybatis查询返回Map<String,Object>类型实例详解_第7张图片

 测试结果

Mybatis查询返回Map<String,Object>类型实例详解_第8张图片

总结

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

你可能感兴趣的:(Mybatis查询返回Map类型实例详解)