Mybatis框架
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