Mybatis中3种关联关系的实现方法示例

 更新时间:2019年11月02日 10:29:24   作者:一入码坑深似海  
这篇文章主要给大家介绍了关于Mybatis中3种关联关系的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者使用Mybatis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

三种关联关系:一对多,一对一,多对多

两种查询方式:嵌套查询,连接查询(也可称作:多表单独查询,多表连接查询)

每一种关联关系都可以通过嵌套查询和连接查询来实现。

嵌套查询相当于进行了两次查询,而连接查询将两张表连接然后再进行查询,这样只进行了一次查询

由于数据表要对实体类进行映射,所以每一种关联关系中都需要在java类中定义属性来进行关联,可以通过如图关联:


一对一查询

数据表实现:通过A表的主键引用B表的主键作为外键,就是说在A中主键和外键同一字段。

查询方式:嵌套查询,连接查询;

关系:丈夫和妻子(Husband Wife)

嵌套查询实现:


在实体类husband中关联wife,进行连接查询之后,需要使用resultMap对查出来的结果进行结果映射;

resultMap中type属性指定映射的类型;id标签为主键,result为普通属性;

association标签指定关联一个类,property属性是它在数据表中的属性名,javaType是关联属性的java类型;

连接查询实现:


其中association标签中:

select属性: 加载另外一个映射语句,可以加载这个属性映射需要的复杂类型,(就是可以再加载指定的映射类型)

column属性:用于给select传递参数,可以将已经获取到的属性值,传递给目标 select 语句作为参数;

一对多查询

数据表实现:使用一个外键进行关联,外键放在多方的表中;

关联属性:可以写在一方的实体类中也可以写在多方的实体类中;

  1. 写在一方中,使用list或别的集合进行关联(一方找多方)
  2. 写在多方中,定义关联对象属性(通过多方找一方)

以多表连接查询为例:

关系:一个国家对应多个部长


通过resultMap进行结果映射,collection标签可以指定映射的集合,其中porperty属性指定的是该关联属性的名称,ofType指定的是集合里面的java类型,id,result标签同resultMap中的一样是对集合里面的属性进行映射;

多表单独查询(嵌套查询):


与一对一中类似,在resultMap的collection中声明中元素类型,然后插入参数,将查询结果进行映射;

自关联查询:

数据表:一张数据表中包含着所有的条目,条目之间为一对多的关系(一个栏目下面包含着多个栏目)

查询方式:连接查询(自己连接自己)和嵌套查询(调用自身查询)

以嵌套查询为例:


这是通过父栏目查询子栏目的自关联查询:

在resultMap中collection的select中调用原来的查询语句进行查询,形成一个循环调用,一直到查询到的子栏目为空的时候停止;最后对查询结果进行映射。

当然,也可通过子栏目查找它的所有的父栏目;

多对多查询

数据表:需要用一张中间表表示多对多的关系,这张中间表引入两张表的主键作为外键;

查询方式:

  1. 多表连接查询,不需要定义中间表实体类
  2. 多表嵌套查询,需要定义中间表实体类
  3. 多表复杂查询,不需要定义中间表实体类,但是返回值是一个List;

多表嵌套查询定义中间实体类:

由于两张表之间分别单独查询,需要通过中间表查找关联并使用resultMap进行映射关系处理,resultMap需要指明映射的java的类,并在实体类中定义关联属性才可以得到关联属性的信息;简单来说:一张表查询完之后想要得到另一张表的信息,实际上是通过中间表来进行映射得到另一张表的信息的;

多表复杂查询:通过一张表先和中间表进行连接查询,然后再查询另一张表的信息;


复杂查询返回值是一个List:

由于一张表先和中间表连接,而中间表是多对多的关系;所以得到一个一对多的List形式查询结果;

类似这样一对多:


总结:

实际上除了数据库的知识以外,Mybatis中的关联关系实现,主要通过resultMap来实现的

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

相关文章

  • Java Swing实现记事本页面

    Java Swing实现记事本页面

    这篇文章主要为大家详细介绍了Java Swing实现记事本页面,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Java超详细梳理IO流的使用方法上

    Java超详细梳理IO流的使用方法上

    流(Stream)是指一连串的数据(字符或字节),是以先进先出的方式发送信息的通道,数据源发送的数据经过这个通道到达目的地,按流向区分为输入流和输出流
    2022-04-04
  • SpringBoot与SpringSecurity整合方法附源码

    SpringBoot与SpringSecurity整合方法附源码

    这篇文章主要介绍了SpringBoot与SpringSecurity整合,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 详细聊一聊java中封装的那点事

    详细聊一聊java中封装的那点事

    封装是一个非常广泛的概念,小到一个属性的封装,大到一个框架或者一个项目的封装,下面这篇文章主要给大家介绍了关于java中封装的那点事,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • Java 常量池详解之class文件常量池 和class运行时常量池

    Java 常量池详解之class文件常量池 和class运行时常量池

    这篇文章主要介绍了Java 常量池详解之class文件常量池 和class运行时常量池,常量池主要存放两大类常量:字面量,符号引用,本文结合示例代码对java class常量池相关知识介绍的非常详细,需要的朋友可以参考下
    2022-12-12
  • 详解如何在Spring中为@Value注解设置默认值

    详解如何在Spring中为@Value注解设置默认值

    在Spring开发中,我们经常会遇到需要从配置文件中读取属性的情况,@Value注解是Spring提供的一种便捷方式,能够让我们轻松地将配置文件中的属性注入到Spring Bean中,
    2024-10-10
  • 解决springboot报错Could not resolve placeholder‘xxx‘ in value“${XXXX}

    解决springboot报错Could not resolve placeholder‘x

    这篇文章主要介绍了解决springboot报错:Could not resolve placeholder ‘xxx‘ in value “${XXXX}问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • JdbcTemplate操作数据库的具体方法

    JdbcTemplate操作数据库的具体方法

    这篇文章主要介绍了JdbcTemplate操作数据库的具体操作方法,准备工作需要大家先导入相关的jar包,建个数据库,具体操作方法跟随小编一起看看吧
    2022-03-03
  • vue+springboot上传文件、图片、视频及回显到前端详解

    vue+springboot上传文件、图片、视频及回显到前端详解

    一般来说vue可以使用axios或者fetch等ajax库发送文件请求,而springboot则可以使用Spring MVC的方式来处理上传文件请求,下面这篇文章主要给大家介绍了关于vue+springboot上传文件、图片、视频及回显到前端的相关资料,需要的朋友可以参考下
    2023-04-04
  • Java枚举学习之定义和基本特性详解

    Java枚举学习之定义和基本特性详解

    枚举是JAVA 5.0后增加的一个重要类型。可以用来表示一组取值范围固定的变量。本文将通过示例为大家详细讲解枚举的定义和基本特性,感兴趣的可以了解一下
    2022-08-08

最新评论