Mybatis--查询collection--ListString

2024-04-12 07:18

本文主要是介绍Mybatis--查询collection--ListString,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 描述下场景,比如一个人有多个qq号(假设一个人可以有重复的qq号)数据库结构,有两张表:
people表
id	name
1	jackpeople_qq表
id	people_id	qq
1	1	123456
2	1	234567
3	1	456789
4	1	123456实体类:import java.io.Serializable;  
import java.util.List;  public class People implements Serializable{  private static final long serialVersionUID = -5935066186174346694L;  private Long id;  private String name;  private List<String> qqs;  public Long getId() {  return id;  }  public void setId(Long id) {  this.id = id;  }  public String getName() {  return name;  }  public void setName(String name) {  this.name = name;  }  public List<String> getQqs() {  return qqs;  }  public void setQqs(List<String> qqs) {  this.qqs = qqs;  }  @Override  public String toString() {  return "People [id=" + id + ", name=" + name + ", qqs=" + qqs + "]";  }  
}  mapper接口:import com.hnpicheng.mybatisissue.domain.People;  public interface PeopleMapper {  People selectPeopleById( Long id);  
}  测试代码:import org.springframework.context.support.ClassPathXmlApplicationContext;  
import com.hnpicheng.mybatisissue.domain.People;  
import com.hnpicheng.mybatisissue.mapper.PeopleMapper;  public class App   
{  public static void main( String[] args )  {  ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("spring-mybatis.xml");  PeopleMapper peopleMapper = context.getBean(PeopleMapper.class);  People p = peopleMapper.selectPeopleById(1L);  System.out.println(p);  }  
}  PeopleMapper.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.hnpicheng.mybatisissue.mapper.PeopleMapper">  <resultMap id="peopleResultMap" type="People">  <id property="id" column="id" />  <result property="name" column="name" />   <collection property="qqs" ofType="string" javaType="list">  <result column="qq" />  </collection>  </resultMap>  <select id="selectPeopleById" resultMap="peopleResultMap">  select p.*,pq.qq from  people p left join  people_qq pq on p.id = pq.people_id   where p.id = #{id}  </select>  
</mapper>  测试结果,优点只要查一次,对于需要排重的查询业务,可以用这个方法:DEBUG [main] - ==>  Preparing: select p.*,pq.qq from people p left join people_qq pq on p.id = pq.people_id where p.id = ?   
DEBUG [main] - ==> Parameters: 1(Long)  
DEBUG [main] - <==      Total: 4  
People [id=1, name=jack, qqs=[123456, 234567, 456789]]  若果需要将重复数据查询出来,那么可以使用以下配置<?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.hnpicheng.mybatisissue.mapper.PeopleMapper">  
<resultMap id="peopleResultMap" type="People">  <id property="id" column="id" />  <result property="name" column="name" />   <collection property="qqs" column="id" select="selectQQByPeopleId">  这里的column是指调用selectQQByPeopleId传递的参数<result column="qq" />  </collection>  </resultMap>  <select id="selectPeopleById" resultMap="peopleResultMap">  select * from people where id = #{id}  </select>  <select id="selectQQByPeopleId" resultType="string">  select qq from people_qq where people_id = #{id}  </select>  
</mapper>  测试结果:DEBUG [main] - ==>  Preparing: select * from people where id = ?   
DEBUG [main] - ==> Parameters: 1(Long)  
DEBUG [main] - <==      Total: 1  
DEBUG [main] - ==>  Preparing: select qq from people_qq where people_id = ?   
DEBUG [main] - ==> Parameters: 1(Long)  
DEBUG [main] - <==      Total: 4  
People [id=1, name=jack, qqs=[123456, 234567, 456789, 123456]]  

这篇关于Mybatis--查询collection--ListString的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/896466

相关文章

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复

mysql查询使用_rowid虚拟列的示例

《mysql查询使用_rowid虚拟列的示例》MySQL中,_rowid是InnoDB虚拟列,用于无主键表的行ID查询,若存在主键或唯一列,则指向其,否则使用隐藏ID(不稳定),推荐使用ROW_NUM... 目录1. 基本查询(适用于没有主键的表)2. 检查表是否支持 _rowid3. 注意事项4. 最佳实