在学数据库概论的时候会听到这么几个词:数据库的关系分为一对一、一对多、多对多。对于在学校里学的知识已经忘得差不多了,在这里简单的提一下数据库的关系。此篇是介绍MyBatis是如何实现数据库中一对一关系的,我们就暂且先介绍一对一关系。所谓一对一关系其实在生活中很常见,比如一个学生有且只对应一个属于他的学生证。下面就是我们的所假设的数据库物理模型。

在这个数据库模型中,学生证和学生表是1对1的关系。那么基于此,我们会在Java代码的POJO包中就会有两个POJO对象,Student和SelfCard 。那么在Student这个学生信息类中就不应仅仅包含3个字段,它应该关联StudentCard。例如Student类:

 public class Student {
private int id;
private String name;
private String sex;
private SelfCard selfCard;
//省略get/set方法
}

SelfCard类:

 public class SelfCard {
private int id;
private int studentId;
private String note;
}

现在的需求是,根据id查询出学生信息(包括学生证的信息),这个时候怎么办呢?我现在仍然记得在学校的时候是怎么处理这种情况的,先根据id查询出student表中的学生基本信息,再根据studentId在SelfCard学生证中的该学生信息,将查询出来的学生证信息赋值给studentPOJO类。现在想想用这种办法也是简直了。我们大可不必用这种low的方式,这里的根据id查询学生信息(包括学生证信息)其实就是一个数据库的1对1级联关系,我们可以用inner join的sql语句来查询,当然我们也可以使用Mybatis为我们提供的association一对一级联。

不可避免的我们始终会查询根据studentId查询该学生的学生证信息,所以我们还是会有SelfCardMapper.java和SelfCardMapper.xml。

 package day_8_mybatis.mapper;

 import day_8_mybatis.pojo.SelfCard;

 /**
* @author turbo
*
* 2016年11月2日
*/
public interface SelfCardMapper {
SelfCard findSelfCardByStudentId(int studentId);
}
 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="day_8_mybatis.mapper.SelfCardMapper">
<resultMap type="day_8_mybatis.pojo.SelfCard" id="studentSelfCardMap">
<id property="id" column="id"/>
<result property="studentId" column="student_id"/>
<result property="note" column="note"/>
</resultMap>
<select id="findSelfCardByStudentId" parameterType="int" resultMap="studentSelfCardMap">
select id, student_id, note from t_student_selfcard where student_id = #{id}
</select>
</mapper>

当然我们对StudentMapper.java的DAO接口也很简单,也很普通,这时还并无特别之处,按照正常的根据id查询返回Student实例就可。

 package day_8_mybatis.mapper;

 import day_8_mybatis.pojo.Student;

 /**
* @author turbo
*
* 2016年11月2日
*/
public interface StudentMapper {
Student getStudent(int id);
}

接下来的StudentMapper.xml就是关键了。

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="day_8_mybatis.mapper.StudentMapper">
<resultMap type="day_8_mybatis.pojo.Student" id="studentMap">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="sex" column="sex"/>
<association property="selfCard" column="id" select="day_8_mybatis.mapper.SelfCardMapper.findSelfCardByStudentId"/>
</resultMap>
<select id="getStudent" parameterType="int" resultMap="studentMap">
select id, name, sex from t_student where id = #{id}
</select>
</mapper>

还记得Student类中有一个SelfCard类的引用吧,它们是一对一的级联关系,在第10行代码中我们使用MyBatis提供的assocation关键字来表示它们是一对一的关系。最后别忘了在配置文件中注册mapper映射器。好了,到现在为止,我们就实现了数据库中的一对一级联关系。接下来就是数据库中一对多级联。

MyBatis之级联——一对一关系的更多相关文章

  1. 0049 MyBatis关联映射--一对一关系

    世上的事务总不是孤立存在的,表现在Java类里面,则是类与类之间的关系,比如继承is-a.依赖use-a.关联has-a,反映在数据库中,则是表与表之间的关系,比如外键 关联关系存在着以下几种类型:一 ...

  2. mybatis之级联关系(一对一、一对多)

    0. 表结构 1. 准备工作 1.1 配置文件等信息,请参考  myBatis之入门示例 1.2 entity 1.2.1 TPersonInfo.java package com.blueStarW ...

  3. MyBatis之级联——一对多关系

    上次我们讲到了MyBatis的一对一关系的表示,简单回顾一下一对一关系就是一个学生只有一个学生证.那么什么是一对多关系呢?一个学生有多个课程这就是一对多的关系.我们结合上一章中的学生和学生证,在此基础 ...

  4. Hibernate 集合映射 一对多多对一 inverse属性 + cascade级联属性 多对多 一对一 关系映射

    1 . 集合映射 需求:购物商城,用户有多个地址. // javabean设计 // javabean设计 public class User { private int userId; privat ...

  5. 创建以mybatis为基础的web项目(2)mabitis中的一对一关系项目实战

    mabitis中的一对一关系项目实战: 1.首先根据创建以mybatis为基础的web项目(1)中的流程将web项目部署好 打开IDE,建立web工程 在lib下面粘贴mybatis的jar,log4 ...

  6. MyBatis日记(五):一对一关系,一对多关系

    一对一关系: 首先在数据库中新增地址表(t_address)用于存储人员的地址信息: CREATE TABLE `t_address` ( `id` ) NOT NULL AUTO_INCREMENT ...

  7. (五)mybatis之一对一关系

    一.需求分析 需求:查询订单信息关联查询用户信息 分析:一条订单只能由一个消费者来下单,也就是说从订单的角度来说与消费者是一对一的关系. 二.建数据库表和实体对象 其中订单表中的字段user_id对应 ...

  8. mybatis的动态sql编写以及一对一关系查询和一对多的查询

    创建mybatis数据库,运行以下sql语句 /* SQLyog Ultimate v8.32 MySQL - 5.5.27 : Database - mybatis **************** ...

  9. MyBatis——一对多、一对一关系,collection、association

    实体类两个: user类: package com.pojo; /** *用户 */ public class User{ private int userId;//用户ID private Stri ...

随机推荐

  1. 从PRINCE2引起项目失败的共性原因?

    一.项目与组织的关键战略优先排序之间缺乏明确的联系 项目必须体现和贯彻发起者的目标.每个项目是怎样支持这些目标的,怎样对项目进行优先排序能提供最大的回报,这些都应该能明确地表述出来. PRINCE2持 ...

  2. MongoDB基础教程系列--第二篇 MongoDB基本操作(一)

    1.安装环境 在官网上下载MongoDB的最新版本,根据自身Windows版本下载正确的MongoDB版本.下载后,双击32位或者64位.msi文件,按操作提示安装就可以了. 说明: 32 位版本的 ...

  3. XJOI1571爱心蜗牛【树形动规】

    爱心蜗牛 猫猫把嘴伸进池子里,正准备"吸"鱼吃,却听到门铃响了.猫猫擦了擦脸上的水,打开门一看,那人正是她的好朋友--川川.川川手里拿着一辆玩具汽车,对猫猫说:"这是我的 ...

  4. SSH程序框架的整合(1)

    spring整合hibernate 有两种方式 1.注解方式 2.xml方式实现 Spring整合Hibernate有什么好处? 1.由IOC容器来管理Hibernate的SessionFactory ...

  5. Java反射理解

    序言 一般而言,动态语言是指程序运行时,允许改变程序结构或变量类型的语言. 从这个观点来看,Perl.Python.Ruby是动态语言,C++.Java.C#不是动态语言. 但是Java有动态相关机制 ...

  6. fixed应用

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  7. android布局中画线的方法

    1.自定义View画线 http://fariytale.iteye.com/blog/1264225 下面介绍几种简单的方法 2.textView和View画直线 <TextView andr ...

  8. 常见BOM实用对象

    1.跨浏览器获取窗口左边上边位置 2.IE9+.Chrome.Safari.Opera.Firefox支持下列属性. innerheight 返回浏览器窗口本身的高度. innerwidth  返回浏 ...

  9. 手机QQ无法临时会话的解决方案

    手机网页发起临时会话:    <a href="mqqwpa://im/chat?chat_type=wpa&uin=3355135984&version=1& ...

  10. 2017-4-18 ADO.NET

    1.什么是ADO.NET?     (是一种数据库访问技术) ADO.NET的名称起源于ADO(ActiveX Data Objects),是一个COM组件库,用于在以往的Microsoft技术中访问 ...