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

这篇具有很好参考价值的文章主要介绍了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>类型,但是只能接收一条数据,数据超过一条会报错。如下

mybatis返回map<string,object>,spring boot,java,eureka

 第二种: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

mybatis返回map<string,object>,spring boot,java,eureka

测试一下mybatis返回map<string,object>,spring boot,java,eureka

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

单表查询返回多条数据

 Mapper层

mybatis返回map<string,object>,spring boot,java,eureka

 Mapper.xml

mybatis返回map<string,object>,spring boot,java,eureka

 测试一下

mybatis返回map<string,object>,spring boot,java,eureka

多表查询返回多条数据

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层

mybatis返回map<string,object>,spring boot,java,eureka

 Mapper.xml

mybatis返回map<string,object>,spring boot,java,eureka

 测试结果

mybatis返回map<string,object>,spring boot,java,eureka文章来源地址https://www.toymoban.com/news/detail-785796.html

到了这里,关于Mybatis查询返回Map<String,Object>类型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包