MyBatis 表连接查询写法|三种对应关系

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

❤️作者主页微凉秋意
✅作者简介后端领域优质创作者🏆CSDN内容合伙人🏆阿里云专家博主🏆
✨精品专栏C++面向对象
🔥系列专栏JavaWeb

文章目录


前言

上篇博文把基础部分记录了本篇是对 表连接查询 中一对一一对多多对多关系写法区别的记录总结。

表连接查询

  • 前提最少是两张表其中的子表设有外键
  • 按对应关系可分为
    • 一对一
    • 一对多
    • 多对多

对于主外键的关系搞不清楚的可以参考我以往的博文mysql一点通

一对一关系

有如下两张表格t_people人与t_passport护照

在这里插入图片描述
在这里插入图片描述

一个人对应一本护照同时一本护照对应一个人而且人不一定有护照有护照一定会有人存在。
因此外键应设在护照表中那么就该创建类了

// Passport
public class Passport {
    private Integer passportId;
    private String passportSerial;
}
// People
public class People {
    private Integer peopleId;
    private String  peopleName;
    private Passport passport;
}

这样创建非常符合表之间的逻辑关系但是创建方式并不唯一。
在Passport类中添加People属性也是可以的即

// Passport
public class Passport {
    private Integer passportId;
    private String passportSerial;
    private People people;
}
// People
public class People {
    private Integer peopleId;
    private String  peopleName;
}

那实际做项目时应该如何取舍答案是根据需求

  • 如果是查询公民以及其对应的护照信息那就用前者
  • 如果是查询所有护照以及持有者的信息那就用后者
  • 因此在设计类时不要太死板两种方法需要斟酌后选择

这里以查询公民以及其对应的护照信息为例编写项目

在mapper接口定义方法

public interface PeopleMapper {
    List<People> selectAll();
}

在xml中编写sql

<mapper namespace="com.qj.mapper.PeopleMapper">
    <resultMap id="peopleMap" type="People">
        <id property="peopleId" column="people_id"/>
        <result property="peopleName" column="people_name"/>
        <association property="passport" javaType="Passport">
            <id property="passportId" column="passport_id"/>
            <result property="passportSerial" column="passport_serial"/>
        </association>
    </resultMap>

    <select id="selectAll" resultMap="peopleMap">
        select *
        from t_people t1
                 left join t_passport t2 on t1.people_id = t2.people_id
    </select>
</mapper>

重点在于resultMap里的写法

  • association 标签用于一对一关系
    • propetry 后写属性名
    • javaType 后写该属性所属类的类型

编写测试类

public static void main(String[] args) {
    SqlSession sqlSession = MybatisUtil.getSqlSession();
    PeopleMapper mapper = sqlSession.getMapper(PeopleMapper.class);
    mapper.selectAll().forEach(System.out::println);
    MybatisUtil.closeSqlSession(sqlSession);
}

这段代码mapper.selectAll().forEach(System.out::println); 中的写法是在JDK1.8之后有的

  • 格式集合.foreach(打印方法)

运行结果
在这里插入图片描述

一对多关系

有如下两张表格t_user用户t_order订单:
在这里插入图片描述
在这里插入图片描述

用户可以下多个订单一个订单对应一个用户这就是一种一对多关系。

查询用户及其所有订单信息

// Order
public class Order {
    private Integer orderId;
    private String orderName;
}
// User
public class User {
    private Integer uId;
    private String userName;
    private String userPwd;
    private List<Order> orders;
}

xml文件的写法

<mapper namespace="com.qj.mapper.UserMapper">
    <resultMap id="userMap" type="User">
        <id property="uId" column="u_id"/>
        <result property="userName" column="u_username"/>
        <result property="userPwd" column="u_pwd"/>
        <collection property="orders" javaType="java.util.List" ofType="Order">
            <id property="orderId" column="order_id"/>
            <result property="orderName" column="order_name"/>
        </collection>
    </resultMap>

    <select id="selectAll" resultMap="userMap">
        select *
        from t_user t1
                 left join t_order t2
                           on t1.u_id = t2.user_id
    </select>

</mapper>

这里与一对一的区别就在于使用的标签不同

  • collection 标签
    • property后写属性名
    • javaType后写集合类型
    • ofType后写泛型的类型

测试结果
在这里插入图片描述

多对多关系

有以下三张表格表示了学生的选课情况
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

一个学生可以选多个课程而一个课程可以被多个学生选择这就是典型的多对多关系。

而 多对多 与 一对多 关系在xml文件中resultMap的写法几乎一致因此不做过多解释看一下sql 语句与测试结果即可

<select id="selectAll" resultMap="stuMap">
        select *
        from t_stu t1
                 left join t_sc t2 on t1.stu_id = t2.s_id
                 left join t_course t3 on t3.course_id = t2.c_id
    </select>

在这里插入图片描述


下篇总结 mybatis 动态sql、常用的标签以及缓存的有关知识需要的小伙伴记得订阅专栏。

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6