今天小编给大家分享一下Mybatis查询返回Map<String,Object>类型实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
首先我们在企业开发中是很少使用到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>>类型,返回的是一个集合,可以接收多条数据
第三种: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
测试一下
第三种:Map<String, Map<String,Object> >
Mapper层
Mapper.xml
测试结果
以上就是“Mybatis查询返回Map<String,Object>类型实例分析”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。