mybatis 一对多关联查询

以篮球队和篮球运动员为例,一个篮球队关联着多个篮球队员

 

创建球队的表,里面有两个字段:
id:主键
name:球队名称

CREATE TABLE `t_team` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(45) NULL,
  PRIMARY KEY (`id`));

创建球员的表,有三个字段:
id:主键
name:球员姓名
tid:所在球队的主键id

CREATE TABLE `t_player` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(45) NULL,
  `tid` INT NULL,  /* 所在球队的主键id */
  PRIMARY KEY (`id`));

 

创建篮球运动员的类Player:

复制代码
/**
 * 篮球队员
 */
public class Player {

    private int id;
    private String name;

    @Override
    public String toString() {
        return "Player{" +   "id=" + id +  ", name='" + name + '\'' +   '}';
    }
    //省略setter和getter
}
复制代码

创建球队的类Team,这里将球员数据全部放到一个List集合中:

复制代码
import java.util.List;

/**
 * 篮球队
 */
public class Team {

    private int id;
    private String name;

    private List<Player> playerList;

    @Override
    public String toString() {
        return "Team{" +   "id=" + id +   ", name='" + name + '\'' +   ", playerList=" + playerList +  '}';
    }
    //省略setter和getter
}
复制代码

创建TeamMapper.xml映射文件:

此时涉及到两张表的操作,即使你的字段名和bean属性名一致也要编写resultMap来进行关联。

复制代码
<?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.monkey1024.dao.TeamDao">

    <resultMap id="teamMap" type="Team">
        <!--team中的基本属性-->
        <id column="teamid" property="id"/>
        <result column="tname" property="name"/>

        <!--关联属性的映射关系-->
        <collection property="playerList" ofType="Player">
            <id column="pid" property="id"/>
            <result column="pname" property="name"/>
        </collection>
    </resultMap>


    <select id="selectTeamById" resultMap="teamMap">
        SELECT t.id teamid,t.name tname,p.id pid,p.name pname
        FROM t_team t , t_player p
        WHERE t.id = p.tid and t.id=#{id}
    </select>
</mapper>
复制代码

上面sql语句中的collection标签可以表示集合类型,其中:

  • property 中填写集合在Team 中的属性名称,此时是 playerList
  • ofType 中填写集合的泛型

在collection标签中填写的内容关联的是Player中的属性。

 

 

 

REF

http://www.monkey1024.com/framework/1366

 

posted @   emanlee  阅读(203)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
历史上的今天:
2020-12-23 highcharts network 网络图
2020-12-23 java字符串多行写法
2015-12-23 tophat cufflinks cuffcompare cuffmerge 的使用
2015-12-23 shell 随机从文件中抽取若干行
2013-12-23 shell/bash 让vi/vim显示空格,及tab字符
2013-12-23 shell/bash 交集、并集、差集
2011-12-23 主分量分析
点击右上角即可分享
微信分享提示