MyBatis实现表连接查询写法(三种对应关系)的方法总结

 更新时间:2023年01月28日 09:36:41   作者:微凉秋意  
这篇文章主要介绍了MyBatis实现表连接查询写法(一对一关系、一对多关系、多对多关系)的方法,文中的示例代码讲解详细,感兴趣的可以了解一下

前言

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

表连接查询

前提最少是两张表,其中的子表设有外键

按对应关系可分为:

  • 一对一
  • 一对多
  • 多对多

对于主外键的关系搞不清楚的可以参考我以往的博文: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实现表连接查询写法(三种对应关系)的方法总结的文章就介绍到这了,更多相关MyBatis表连接查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何基于java随机获取不重复数值

    如何基于java随机获取不重复数值

    这篇文章主要介绍了如何基于java随机获取不重复数值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Java 线程优先级详解及实例

    Java 线程优先级详解及实例

    这篇文章主要介绍了Java 线程优先级详解及实例的相关资料,需要的朋友可以参考下
    2017-04-04
  • Python爬虫 12306抢票开源代码过程详解

    Python爬虫 12306抢票开源代码过程详解

    这篇文章主要介绍了Python爬虫 12306抢票开源代码过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • SpringBoot详解Banner的使用

    SpringBoot详解Banner的使用

    这篇文章主要介绍了超个性修改SpringBoot项目的启动banner的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 学习Java的9张思维导图

    学习Java的9张思维导图

    这篇文章主要为大家详细介绍了学习Java的9张思维导图,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • Spring如何基于aop实现操作日志功能

    Spring如何基于aop实现操作日志功能

    这篇文章主要介绍了Spring如何基于aop实现操作日志功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • java正则实现各种日期格式化

    java正则实现各种日期格式化

    本文给大家分享的是使用java结合正则表达式来实现各种日期的格式化功能,代码非常的简单,有需要的小伙伴可以参考下。
    2015-05-05
  • springboot远程debug调试全过程

    springboot远程debug调试全过程

    这篇文章主要介绍了springboot远程debug调试全过程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • java的几种定时器的具体使用(4种)

    java的几种定时器的具体使用(4种)

    本文主要介绍了4种类型的定时器:@Scheduled注解、quartz、new Timer().schedule、使用线程控制的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2021-09-09
  • springboot如何根据配置屏蔽接口返回字段

    springboot如何根据配置屏蔽接口返回字段

    这篇文章主要介绍了springboot如何根据配置屏蔽接口返回字段问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08

最新评论