返回顶部
首页 > 资讯 > 数据库 >MyBatis 表连接查询写法|三种对应关系
  • 927
分享到

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

mybatisjavamysql数据库 2023-08-23 18:08:54 927人浏览 安东尼
摘要

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

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


前言

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

表连接查询

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

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

一对一关系

有如下两张表格,t_people(人)与t_passport(护照):

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

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

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

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

// Passportpublic class Passport {    private Integer passportId;    private String passportSerial;    private People people;}// Peoplepublic 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(订单):
在这里插入图片描述
在这里插入图片描述

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

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

// Orderpublic class Order {    private Integer orderId;    private String orderName;}// Userpublic 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、常用的标签以及缓存的有关知识,需要的小伙伴记得订阅专栏。

来源地址:https://blog.csdn.net/m0_58618795/article/details/128765757

您可能感兴趣的文档:

--结束END--

本文标题: MyBatis 表连接查询写法|三种对应关系

本文链接: https://lsjlt.com/news/378799.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作