Mybatis一对多关系映射

本文介绍了如何使用MyBatis进行分步查询和集合处理,包括在ClatwoMapper中通过left join查询班级及学生信息,以及通过分步查询实现类和学生信息的分离加载。示例代码展示了ClatwoMapper和StudentoneMapper的XML配置,以及对应的Java接口方法。测试用例演示了查询过程并打印查询结果。
摘要由CSDN通过智能技术生成

数据库表:
t_class
在这里插入图片描述
t_student
在这里插入图片描述
实体类:
Student.java

public class Student {
    private Integer sid;
    private String name;
    private Cla cla;

    public Student() {
    }

    public Student(Integer sid, String name) {
        this.sid = sid;
        this.name = name;
    }

    public Integer getSid() {
        return sid;
    }

    public void setSid(Integer sid) {
        this.sid = sid;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Cla getCla() {
        return cla;
    }

    public void setCla(Cla cla) {
        this.cla = cla;
    }

    @Override
    public String toString() {
        return "Student{" +
                "sid=" + sid +
                ", name='" + name + '\'' +
                ", cla=" + cla +
                '}';
    }
}

Cla.java

package com.example.mybatis;

import java.util.List;

public class Cla {
    private Integer cid;
    private String cname;
    private List<Student> students;

    @Override
    public String toString() {
        return "Cla{" +
                "cid=" + cid +
                ", cname='" + cname + '\'' +
                ", students=" + students +
                '}';
    }

    public List<Student> getStudents() {
        return students;
    }

    public void setStudents(List<Student> students) {
        this.students = students;
    }
    public Cla() {
    }

    public Cla(Integer cid, String cname) {
        this.cid = cid;
        this.cname = cname;
    }

    public Integer getCid() {
        return cid;
    }

    public void setCid(Integer cid) {
        this.cid = cid;
    }

    public String getCname() {
        return cname;
    }

    public void setCname(String cname) {
        this.cname = cname;
    }
}

一、collection处理

ClatwoMapper.java

package com.example.mybatis;

import org.apache.ibatis.annotations.Param;

public interface ClatwoMapper {

    Cla getquery(@Param("cid") Integer cid);
}

ClatwoMapper.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.example.mybatis.ClatwoMapper">
    <resultMap id="get" type="com.example.mybatis.Cla">
        <id property="cid" column="cid"></id>
        <result property="cname" column="cname"></result>
        <collection property="students" ofType="com.example.mybatis.Student">
            <id property="sid" column="sid"></id>
            <result property="name" column="name"></result>
        </collection>
    </resultMap>
    <select id="getquery" resultMap="get">
        select cla.*,student.* from t_class cla left join t_student student on cla.cid = student.cid where cla.cid = #{cid}
    </select>
</mapper>

test.java

    @Test
    public void getquery() throws IOException {
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        SqlSession sqlSession = sqlSessionFactoryBuilder.build(is).openSession(true);
        Cla getquery = sqlSession.getMapper(ClatwoMapper.class).getquery(1);
        System.out.println(getquery);
    }

在这里插入图片描述
二、分步查询
ClatwoMapper.java

package com.example.mybatis;

import org.apache.ibatis.annotations.Param;

public interface ClatwoMapper {

 Cla getClaAndStuone(@Param("cid") Integer cid);
}

ClatwoMapper.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.example.mybatis.ClatwoMapper">
<resultMap id="ClaAndStu" type="com.example.mybatis.Cla">
        <id property="cid" column="cid"></id>
        <result property="cname" column="cname"></result>
        <collection property="students"
                    select="com.example.mybatis.StudentoneMapper.getClaAndStutwo"
                    column="cid">
        </collection>
    </resultMap>
    <select id="getClaAndStuone" resultMap="ClaAndStu">
        select * from t_class where cid = #{cid}
    </select>
</mapper>

StudentoneMapper.java

package com.example.mybatis;

import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface StudentoneMapper {
    List<Student> getClaAndStutwo(@Param("cid") Integer cid);
}

StudentoneMapper.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.example.mybatis.StudentoneMapper">
    <select id="getClaAndStutwo" resultType="com.example.mybatis.Student">
        select * from t_student where cid = #{cid}
    </select>
</mapper>

test.java

  @Test
    public void queryClaAndStu() throws IOException {
        InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
        SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
        SqlSession sqlSession = sqlSessionFactoryBuilder.build(is).openSession(true);
        Cla cla = sqlSession.getMapper(ClatwoMapper.class).getClaAndStuone(1);
        System.out.println(cla);
    }

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值