MyBatis 表连接查询写法|三种对应关系
作者:mmseoamin日期:2024-03-20

❤️作者主页:微凉秋意

✅作者简介:后端领域优质创作者🏆,CSDN内容合伙人🏆,阿里云专家博主🏆

✨精品专栏:C++面向对象

🔥系列专栏:JavaWeb

文章目录

  • 前言
  • 表连接查询
    • 一对一关系
    • 一对多关系
    • 多对多关系

      前言

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

      表连接查询

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

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

          一对一关系

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

          MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第1张

          MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第2张

          一个人对应一本护照,同时一本护照对应一个人,而且人不一定有护照,有护照一定会有人存在。

          因此外键应设在护照表中,那么就该创建类了:

          // 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 selectAll();
            }
            

            在xml中编写sql:

            
                
                    
                    
                    
                        
                        
                    
                
                
            
            

            重点在于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(打印方法)

                运行结果:

                MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第3张

                一对多关系

                有如下两张表格,t_user(用户),t_order(订单):

                MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第4张

                MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第5张

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

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

                // 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 orders;
                }
                

                xml文件的写法:

                
                    
                        
                        
                        
                        
                            
                            
                        
                    
                    
                
                

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

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

                    测试结果:

                    MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第6张

                    多对多关系

                    有以下三张表格,表示了学生的选课情况:

                    MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第7张

                    MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第8张

                    MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第9张

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

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

                    
                    

                    MyBatis 表连接查询写法|三种对应关系,在这里插入图片描述,第10张


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