Mybatis查找返回Map,List集合类型的数据方式

Mybatis查找返回Map,List集合类型的数据

一、查找返回Bean对象的List集合

基本与返回Bean对象没什么区别,resultType依然为Bean对象的全类名,只是接口中的方法类型要进行修改

public List<Employee> getEmpListByEmail(String email);

二、查询返回Bean对象的Map集合

同样,resultType依然为Bean对象的全类名,只是接口中的方法类型要进行修改,添加注解。

@MapKey("Bean对象属性名"):指定Map的键为Bean对象的哪个属性,一般设置为主键,因为Map不能存重复的键。

@MapKey("id")
public Map<Integer,Employee> getEmpMapByEmail(String email);

三、查询返回单条纪录的Map集合

即当前记录以键为列名,值为列属性存入map(查询到的记录一定要只有一条,否则报错)

注意,resultType需要设置为map,接口中方法类型需要修改,Map的键默认为列名。

public Map<String, Object> getEmpByEmail(String email);

mybatis 查询返回List集合、map集合、List<Map>集合

返回map类型

1. xml中

<select id="selectUser"  resultType="java.util.HashMap">
</select>  

2.Dao接口中

Map<String,Object> selectUser(); 

这种方式SQL只能返回一行记录或者没有返回,如果返回多行记录,则程序报错。

返回List<String>类型

3. xml中

<select id="selectUser"  resultType="java.lang.String">
</select>  

2.Dao接口中

List<String> selectUser(); 

这种方式可以返回多行记录,但是每行记录只有指定的一列数据。

返回List<Map>类型

1.xml中

<select id="selectUser"  resultType="java.util.HashMap">
</select>  

2.Dao接口中

List<Map<String,Object>> selectUser ();

这种方式可以返回指定的多行多列的记录。

返回List<指定对象>类型

xml中:

<resultMap id="baseResult" type="com.XXX.BscntrUnitInfoResult(对应对象)">
  <result column="unit_id" property="unitId" jdbcType="INTEGER" (字段映射关系)/>
  <result column="unit_name" property="unitName"
   jdbcType="VARCHAR" />
  <result column="unit_type" property="unitType"
   jdbcType="INTEGER" />
  <result column="super_unit_id" property="superUnitId"
   jdbcType="INTEGER" />
  <result column="gis_start_x" property="gisStartX"
   jdbcType="FLOAT" />
  <result column="ext_top" property="extTop" jdbcType="DOUBLE" />
</resultMap>
<select id="getBscntrUnitInfoListByName" resultMap="baseResult">

</select>

Dao接口中:

public List<BscntrUnitInfoResult> getBscntrUnitInfoListByName();

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • MyBatis传入集合 list 数组 map参数的写法

    foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合.foreach元素的属性主要有item,index,collection,open,separator,close.item表示集合中每一个元素进行迭代时的别名,index指定一个名字,用于表示在迭代过程中,每次迭代到的位置,open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔符,close表示以什么结束,在使用foreach的时候最关键的也是最容易出错的就是collection属性

  • Mybatis返回单个实体或者返回List的实现

    Mybatis 的强大之处之一体现在映射语句上,让我们可以使用简单的配置,就可以实现对参数和返回结果的映射. 实体 package com.test.User public class User{ private String userId; private String userName; private String userPassword; private Date createTime; ... setter getter.... } DAO public interface User

  • MyBatis查询返回Map示例代码

    前言 有时候我们做查询, 只需要返回两个string类型的字段,方便我们后续的处理.比如根据商品的code查询对应的分类的名字,需要返回一个map, key为商品code, value为商品分类对应的名称.以方便我们后续对结果集的处理.如果你直接用mybatis返回一个map, 你可能会发现,结果根据不是自己需要的.这时候我们需要自己实现一个ResultHandler来实现我们想要的结果,废话不多说,直接上代码 方法如下 第一步,在mapper.xml文件当中,定义一个ResultMap <re

  • mybatis查询实现返回List<Map>类型数据操作

    如下所示: **只要设定resultType而不设定resultMap就可以了**: < select id = "selectByPage" parameterType = "java.util.Map" resultType="java.util.Map" > select rs.*, rssetting.*, cp.STOCK_CODE, cp.UNAME from RS rs left join T_COMPANY cp on

  • Mybatis查询多条记录并返回List集合的方法

    实体对象如下: /** 使用lobmok插件 */ @Getter @Setter @NoArgsConstructor @ToString @EqualsAndHashCode public class Vendor { private String vend_id; private String vend_name; private String vend_address; private String vend_city; private String vend_state; privat

  • Mybatis查找返回Map,List集合类型的数据方式

    Mybatis查找返回Map,List集合类型的数据 一.查找返回Bean对象的List集合 基本与返回Bean对象没什么区别,resultType依然为Bean对象的全类名,只是接口中的方法类型要进行修改 public List<Employee> getEmpListByEmail(String email); 二.查询返回Bean对象的Map集合 同样,resultType依然为Bean对象的全类名,只是接口中的方法类型要进行修改,添加注解. @MapKey("Bean对象属性

  • mybatis查询返回Map<String,Object>类型的讲解

    目录 查询返回Map<String,Object>类型 mybatis返回结果为Map问题 查询返回Map<String,Object>类型 mybatis 查询返回Map<String,Object> 类型,平时没太注意怎么用,今天又遇到了总结记录一下,方便以后处理此类问题. Mapper.java中的方法: @MapKey("userId") Map<String,UserInfo> personalInfoByUserIds(Lis

  • Mybatis查询返回Map<String,Object>类型实例详解

    这篇我们来说一下Mybatis的查询结果返回Map类型. 首先我们在企业开发中是很少使用到Map返回类型的,很多都是直接返回一个对象实体.尤其是苞米豆出了MP框架之后,XML都是很少写的. 那么在什么情况下需要使用Map来作为返回的结果类型呢? 案例:有一个模块A和模块B,A模块的POM依赖引入了B模块,A模块可以直接使用B模块的实体,但是B模块使用不到A模块的实体,如果在B模块POM中引入A模块的依赖,那么在运行时会出现依赖循环错误,这时候就需要自己写SQL来返回Map类型了,因为返回不了另一

  • Mybatis中返回Map的实现

    在Mybatis中,我们通常会像下边这样用: 返回一个结果 User selectOne(User user); <select id="selectOne" parameterType="cn.lyn4ever.entity.User" resultType="cn.lyn4ever.entity.User"> select id,username,telphone from user where telphone=#{telpho

  • mybatis使用foreach遍历list集合或者array数组方式

    一.准备工作 1.db.properties文件(记得修改自己的数据库和用户名.密码) dataSource.driver=com.mysql.jdbc.Driver dataSource.url=jdbc:mysql://localhost:3306/mybatis?useUnicode=true&characterEncoding=utf8 dataSource.username=blog dataSource.password=blog 2.主配置文件 <?xml version=&q

  • Mybatis resultType返回结果为null的问题排查方式

    目录 resultType返回结果为null的问题 sql语句大致如下 解决办法有下面几种 resultType获取结果一些有值一些为null 原因 配置如下 resultType返回结果为null的问题 sql语句大致如下   <select id="findFinancialProductConfigList" resultType="com.xxx.FinancialProductConfigDTO">     select  <includ

  • Mybatis返回map集合时,列的顺序与select不一致问题

    目录 返回map集合,列的顺序与select不一致 mybatis中返回map集合问题 1.mapper.xml中写一个查询返回map的sql 2.mapper.java 对应接收 3.错误写法 4.正确写法 返回map集合,列的顺序与select不一致 <select id="queryPercentByAsset" resultType="java.util.HashMap"> 将Hashmap换成LinkedHashMap即可 <select

  • .NET性能优化之为集合类型设置初始大小的方法

    目录 前言 集合类型 List源码 Queue.Stack源码 HashSet.Dictionary源码 总结 附录 前言 计划开一个新的系列,来讲一讲在工作中经常用到的性能优化手段.思路和如何发现性能瓶颈,后续有时间的话应该会整理一系列的博文出来.今天要谈的一个性能优化的Tips是一个老生常谈的点,但是也是很多人没有注意的一个点.在使用集合类型是,你应该设置一个预估的初始大小,那么为什么需要这样做?我们一起来从源码的角度说一说. 集合类型 我们先来聊一聊.NET BCL库中提供的集合类型,对于

  • mybatis-plus返回map自动转驼峰配置操作

    mybatis-plus返回map自动转驼峰配置object-wrapper-factory不生效问题解决:配置map-underscore-to-camel-case: true不生效问题解决 很多时候我们工作中查询很多字段的时候一般是返回一个VO来接收,这个时候我们只要在yml中配置了 map-underscore-to-camel-case: true 就会自动将查询数据库的字段带下划线的属性转成对应实体类VO中驼峰命名的属性. 但是会经常有这种场景:例如我们只查询2个字段要返回给前端,这

随机推荐