成都创新互联网站制作重庆分公司

mybatis如何实现一对一关联映射-创新互联

小编给大家分享一下mybatis如何实现一对一关联映射,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

为新兴等地区用户提供了全套网页设计制作服务,及新兴网站建设行业解决方案。主营业务为做网站、网站建设、新兴网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

前言

在客观世界中,对象很少是孤独存在的,如班级与学生之间的关系,学生与课程之间的关系,它们的实例之间可以互相访问,这就是关联关系。MyBatis 的关联映射可以大大简化持久层数据的访问,关联关系的分类如下:

  • 一对一

  • 一对多

  • 多对多

我们首先绘制一个简化的 E-R 图来表示三种关联关系。

mybatis如何实现一对一关联映射

上图表示的三种关系:

  • 一对一:一个班主任只属于一个班级,一个班级也只能有一个班主任

  • 一对多:一个班级有多个学生,一个学生只属于一个班级

  • 多对多:一个学生可以选多门课,一门课可以有多个学生选

引言

而在实际项目开发中,经常存在一对一的关系,如一个人对应一张身份证信息,这就是一对一的关系。下面是一个简单的

实例:

1、建表过程我就省略了,主要是一张Person表,一张IDCard表,其相关属性见步骤2Pojo类属性所示;

2、建立一个Person对象和一个IDCard对象:

mybatis/pri/xiaoyang/otot/pojo/IDCard.java

public class IDCard implements Serializable {
 private int id; // 主键
 private String cardCode; // 身份证编号
 private String carAddress; // 身份证地址
 //构造函数及Getter/Setter/toString...
}

mybatis/pri/xiaoyang/otot/pojo/Person.java

public class Person implements Serializable {
 private int id; // 主键
 private String name; // 姓名
 private String sex; // 性别
 private IDCard iDCard; //身份证对象,人和身份证一对一关系
 //构造函数及Getter/Setter/toString...
}

3、接下来是XML映射文件:

mybatis/pri/xiaoyang/otot/mapper/IDCardMapper.xml


  
 
  select * from idcard where id = #{id}
 

mybatis/pri/xiaoyang/otot/mapper/PersonMapper.xml


 
 
  select * from person where id = #{id}
 
 
 
 
  
  
  
  
  
 

注: 在PersonMapper.xml中定义了一个