mybatis实现一对一关联映射实例代码
前言 在客观世界中,对象很少是孤独存在的,如班级与学生之间的关系,学生与课程之间的关系,它们的实例之间可以互相访问,这就是关联关系。MyBatis 的关联映射可以大大简化持久层数据的访问,关联关系的分类如下:
我们首先绘制一个简化的 E-R 图来表示三种关联关系。 上图表示的三种关系:
引言 而在实际项目开发中,经常存在一对一的关系,如一个人对应一张身份证信息,这就是一对一的关系。下面是一个简单的 实例: 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 <mapper namespace="pri.xiaoyang.otot.mapper.IDCardMapper"> <!-- 根据主键查询IDCard信息,封装为IDCard对象并返回 --> <select id="selectIDCardById" pamaeterType="int" resultType="pri.xiaoyang.otot.pojo.IDCard"> select * from idcard where id = #{id} </select> </mapper> mybatis/pri/xiaoyang/otot/mapper/PersonMapper.xml <mapper namespace="pri.xiaoyang.otot.mapper.PersonMapper"> <!-- 根据person主键查询Person信息,封装为Person对象并返回 --> <select id="selectPersonById" pamaeterType="int" resultMap="PersonMapper"> select * from person where id = #{id} </select> <!-- 映射Person对象的resultMap --> <resultMap type="pri.xiaoyang.otot.pojo.Person" id="PersonMapper"> <id property="id" column="id" /> <result property="name" column="name" /> <result property="sex" column="sex" /> <!-- 一对一关联映射:association --> <association property="iDCard" column="card_id" select="pri.xiaoyang.otot.mapper.IDCardMapper.selectIDCardById" javaType="pri.xiaoyang.otot.pojo.IDCard"/> </resultMap > </mapper> 注: 在PersonMapper.xml中定义了一个<select/>标签,该标签的sql语句是根据Person表的主键字段来查询出唯一的Person信息,由于该Person表和IDCard表关联,因此返回一个resultMap值为personMap的映射对象。personMap使用了<association/>标签映射了一对一的关联关系,其标签内的属性select表示会以column的属性值"card_id"来作为参数执行IDCardMapper中定义的selectIDCardById查询对应的IDCard数据,查询出的数据会被封装到property属性值的“card”对象中。 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |