15-多对多做左连接查询(查询老师,并且把关联的学生也查出来)

多对多左连接查询

目录


 

老师对学生是多对多的关系,把中心放在老师上一个老师可以教多个学生,实际上老师对学生也可以理解为一对多的关系

左连接查询

场景:查询老师,并且把关联的学生也查出来

Teacher.java 映射文件:

@Getter@Setter@ToString
public class Teacher {
    private Integer teacher_id;
    private String teacher_name;

    List<Student> students = new ArrayList<>(); // 一个老师对应多个学生
}

创建一个 TeacherMapper 接口文件,代码如下:

public interface TeacherMapper {
    /*查询老师,并且把关联的学生也查出来*/
    public List<Teacher> getAllTeachers();
}

创建一个 TeacherMapper 的映射文件:

<mapper namespace="com.itlike.mapper.TeacherMapper">

    <select id="getAllTeachers" resultMap="teacherMap">
        SELECT * FROM `teacher` as t
        LEFT JOIN `stu_teacher_rel` as r
        ON t.teacher_id = r.teacher_id
        LEFT JOIN `student` as s
        ON s.stu_id = r.stu_id;
    </select>

    <resultMap id="teacherMap" type="teacher">
        <id column="teacher_id" property="teacher_id"/>
        <result column="teacher_id" property="teacher_id"/>
        <collection property="students" javaType="list" ofType="student">
            <id column="stu_id" property="stu_id"/>
            <result column="stu_name" property="stu_name"/>
        </collection>
    </resultMap>
    
</mapper>

测试类中:

public void test(){
    SqlSession sqlSession = MybatisUtils.openSession();
    TeacherMapper teacherMapper = sqlSession.getMapper(TeacherMapper.class);
    List<Teacher> allTeachers = teacherMapper.getAllTeachers();
    for (Teacher teacher : allTeachers) {
        System.out.println(teacher);
    }

}

运行效果:与数据库查询结果相同。
在这里插入图片描述在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

军刀0923

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值