Mybatis框架(8) —— MyBatis 的对象关系映射

Mybatis框架MyBatis 的对象关系映射准备多表,表之间有外键关系(员工表和部门表)多对一查询一对多查询N+1方式映射代码运行结果等值连接查询映射代码运行结果MyBatis 的对象关系映射在实际开发中,一个业务可能涉及到多个数据表的查询,那么多表查询就涉及连接查询(等值查询),等值查询 表与表之间有一个外键关联但是程序中最终获取的表封装的对象,对象与对象之间是没有外键关系的,对象和对...
摘要由CSDN通过智能技术生成

MyBatis 的对象关系映射

在实际开发中,一个业务可能涉及到多个数据表的查询,那么多表查询就涉及连接查询(等值查询),等值查询 表与表之间有一个外键关联

但是程序中最终获取的表封装的对象,对象与对象之间是没有外键关系的,对象和对象之间只有依赖关系

对象之间的关系主要是四种

一对一 关系 one2one
一个人对应身份证id,一个QQ号对应一个QQ空间

一对多 关系 one2many
一个部门对应多个员工

多对一 关系 many2one
多个员工对应一个部门

多对多 关系 many2many
多个学生对应多个老师,多个学生对应多个课程

什么关系应该从哪个对象作为中心点来看
一对多, 以one方作为中心点

MyBatis框架支持多表查询封装对象之间关系
<collection> 一对多查询
<association>多对一和一对一查询

准备多表,表之间有外键关系(员工表和部门表)

员工表
CREATE TABLE `employee` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) DEFAULT NULL,
  `dept_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
部门表
CREATE TABLE `department` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;

多对一查询

Employee

package cn.xc.mybatis.pojo;

public class Employee {
   
	private Integer id;
	private String name;
	/*
	 * 员工和部门的关系 :多对一 many2one
	 * 
	 * 在员工对象中此时具体的某一个只有一个部门
	 * 
	 * 依赖管理:使用部门对象
	 * 
	 */
	private Department dept;

	public Integer getId() {
   
		return id;
	}

	public void setId(Integer id) {
   
		this.id = id;
	}

	public String getName() {
   
		return name;
	}

	public void setName(String name) {
   
		this.name = name;
	}

	public Department getDept() {
   
		return dept;
	}

	public void setDept(Department dept) {
   
		this.dept = dept;
	}

	public Employee(Integer id, String name, Department dept) {
   
		super();
		this.id = id;
		this.name = name;
		this.dept 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值