解决mybatis一对多关联查询多条数据只显示一条的问题

 更新时间:2020年12月04日 10:54:57   作者:愿你活成你喜欢的模样  
这篇文章主要介绍了解决mybatis一对多关联查询多条数据只显示一条的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

一对多,如果多个表字段名相同,要记住使用别名,否则多条数据只显示一条

<resultMap type="com.example.demo.model.TuserModel" id="extendMapper">
 <id column="id" property="id" />
 <result column="user_name" property="userName" />
 <result column="nick_name" property="nickName" />
 <result column="avatar" property="avatar" />
 <result column="email" property="email" />
 <result column="signature" property="signature" />
 <result column="create_time" property="createTime" />
 <result column="update_time" property="updateTime" />
 <result column="del_flag" property="delFlag" />
 <collection property="tpluginModels" ofType="com.example.demo.model.TpluginModel"
 column="id">
 <id column="pid" property="id" />
 <result column="user_id" property="userId" />
 <result column="name" property="name" />
 <result column="icon" property="icon" />
 <result column="vsersion" property="vsersion" />
 <result column="tags" property="tags" />
 <result column="description" property="description" />
 <result column="bcreate_time" property="createTime" />
 <result column="bupdate_time" property="updateTime" />
 <result column="del_flag" property="delFlag" />
 </collection>
 <!-- <collection property="tpluginModels" column="id" ofType="com.example.demo.model.TpluginModel" 
 select="pluginByUid" /> -->

下列sql

<select id="selectTuserBynameOrNick" resultMap="extendMapper"> select
 u.*,p.id as pid,p.user_id,p.name,p.icon,p.vsersion,p.tags,p.description,p.create_time
 as bcreate_time,p.update_time as bupdate_time,p.del_flag from t_user u
 LEFT
 JOIN t_plugin p ON u.id=p.user_id and u.del_flag=0 and
 p.del_flag=0 WHERE
 u.user_name LIKE CONCAT('%',#{name},'%') OR
 u.nick_name LIKE
 CONCAT('%',#{name},'%')
 </select>

补充知识:MyBatis使用resultMap解决列名和属性名不一致的问题

resultType可以指定将查询结果映射为pojo,但需要pojo的属性名和sql查询的列名一致方可映射成功。

如果sql查询字段名和pojo的属性名不一致,可以通过resultMap将字段名和属性名作一个对应关系 ,resultMap实质上还需要将查询结果映射到pojo对象中。

需求:查询订单表orders的所有数据

SELECT id,user_id,number,createtime,note FROM orders,这里的数据库表user_id与pojo的Order对象中的userId不一致

orders表:

Order对象:

OrderMapper.xml配置:

其中注释掉了另一种使用数据库别名解决列名和属性名不一致的问题

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.sea.crm.mapper.OrderMapper">

 <!-- 使用as 给列取别名解决类名和属性名不一致的情况 -->
 <!--<select id="queryAll" resultType="Order"> SELECT id,user_id as userId,number,createtime,note 
 FROM orders </select> -->
 <!-- 使用resultMap解决列名和属性名不一致的情况 -->
 <!-- 配置一个resultMap映射列和属性 -->
 <resultMap type="Order" id="orderMap">
 <!-- id:设置ResultMap的id -->
 <!-- 定义主键 ,非常重要。如果是多个字段,则定义多个id -->
 <!-- property:主键在pojo中的属性名 -->
 <!-- column:主键在数据库中的列名 -->
 <id column="id" property="id" />
 <!-- 映射其他普通列 -->
 <result column="user_id" property="userId" />
 <result property="number" column="number" />
 <result property="createtime" column="createtime" />
</resultMap>
 <!-- 方法的返回值可以使用 -->
 <select id="queryAll" resultMap="orderMap">
 SELECT id,user_id ,number,createtime,note FROM orders
 </select>
</mapper>

单元测试:

public class OrderMapperTest {
 
 SqlSessionFactory factory = null;
 private OrderMapper orderMapper = null;

 @Before
 public void testInit() {
  // 1. 创建SqlSessionFactoryBuilder对象
  SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
  // 2. 加载SqlMapConfig.xml配置文件
  // /20181013_mybatis/config/SqlMapConfig.xml
  InputStream in = MyBatisTest.class.getResourceAsStream("/SqlMapConfig.xml");
  // 3. 创建SqlSessionFactory对象
  factory = builder.build(in);

 }
    @Test
 public void testqueryAll() {
  SqlSession session = factory.openSession();
  OrderMapper orderMapper = session.getMapper(OrderMapper.class);
  List<Order> orders = orderMapper.queryAll();
  System.out.println(orders);
 }
 }

以上这篇解决mybatis一对多关联查询多条数据只显示一条的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Kibana的安装和配置全过程

    Kibana的安装和配置全过程

    Kibana是一个开源的数据分析和可视化平台,它与Elasticsearch紧密集成,提供了一个直观的Web界面,使您可以快速地搜索、分析和可视化数据,在本文中,我们将介绍如何安装和配置Kibana
    2024-12-12
  • Java面向对象基础之多态性,抽象类和接口

    Java面向对象基础之多态性,抽象类和接口

    这篇文章主要介绍了Java面向对象基础:多态性,抽象类和接口,文中代码可以帮助各位更好的理解学习,有需求的小伙伴可以参考下
    2020-05-05
  • 使用Spring从YAML文件读取内容映射为Map方式

    使用Spring从YAML文件读取内容映射为Map方式

    这篇文章主要介绍了使用Spring从YAML文件读取内容映射为Map方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • Java Annotation注解相关原理代码总结

    Java Annotation注解相关原理代码总结

    这篇文章主要介绍了Java Annotation注解相关原理代码总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07
  • Java安全之URLDNS链使用分析

    Java安全之URLDNS链使用分析

    这篇文章主要介绍了Java安全之URLDNS链使用分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • Java中MapStruct入门使用及对比

    Java中MapStruct入门使用及对比

    MapStruct是一个Java注解处理器框架,用于简化Java Bean之间的映射,本文主要介绍了Java中MapStruct入门使用及对比,感兴趣的可以了解一下
    2023-12-12
  • Java使用正则提取字符串中的内容的详细步骤

    Java使用正则提取字符串中的内容的详细步骤

    这篇文章主要介绍了Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提取场景,以及命名分组、非贪婪匹配等技巧,需要的朋友可以参考下
    2025-08-08
  • Spring中配置和读取多个Properties文件的方式方法

    Spring中配置和读取多个Properties文件的方式方法

    本篇文章主要介绍了Spring中配置和读取多个Properties文件的方式方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-04-04
  • 基于eclipse.ini内存设置的问题详解

    基于eclipse.ini内存设置的问题详解

    本篇文章是对eclipse.ini内存设置的问题进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • Spring中Xml属性配置的解析全过程记录

    Spring中Xml属性配置的解析全过程记录

    这篇文章主要给大家介绍了关于Spring中Xml属性配置的解析全过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03

最新评论