MyBatis级联探讨第一篇——概念和模型

来源:互联网 发布:贵州广电网络机顶盒 编辑:程序博客网 时间:2024/06/06 01:23

谈谈MyBatis级联,文章尽量具体一些。
1、概述
关于MyBatis级联有三种:
association  :一对一的关联
collection   : 一对多的关联
discriminator :鉴别器,
它可以用于鉴别是使用那个resultMapper,或者你暂时不能理解,可以暂时放放。后面我们会再谈。
MyBatis当前只能支持查询的级联,而不能支持新增,删除和更新这些操作。所以这里只会讨论查询的级联。当然首先谈论的是三种级联的用法,然后就是N+1问题,延迟加载的问题。
2、模型  
在讨论这些关联之前,我们需要先定义一个模型。


我们先简单描述一下模型:
我们有一个员工表,一个员工卡表,显然员工和员工卡是一对一的关系。
而员工有男性员工和女性员工所以他们的健康表是不一样的。
一个员工可以参与多个工程,所以有张员工工程表把,员工和工程关联起来了,员工和工程是一对多的关系。
下面笔者给出建表语句:


CREATE TABLE t_employee (   id                 INT(20)              NOT NULL AUTO_INCREMENT,   emp_name           VARCHAR(60)          NOT NULL,  sex                TINYINT(2)              NOT NULL,   PRIMARY KEY (id));CREATE TABLE t_employee_card (   id                 INT(20)              NOT NULL AUTO_INCREMENT,   emp_id             INT(20)              NOT NULL,   card_no            VARCHAR(20)          NOT NULL,   PRIMARY KEY (id));CREATE TABLE t_employee_project (   id                 INT(20)              NOT NULL AUTO_INCREMENT,   emp_id             INT(20),   proj_id             INT(20),   PRIMARY KEY (id));CREATE TABLE t_healthy_male (   id                 INT(20)              NOT NULL AUTO_INCREMENT,   emp_id             INT(20),   prostate           VARCHAR(60),   PRIMARY KEY (id));CREATE TABLE t_healthy_remale (   id                 INTEGER              NOT NULL AUTO_INCREMENT,   emp_id             INT(20),   uterus             VARCHAR(60),   PRIMARY KEY (id));CREATE TABLE t_project (   id                 INT(20)              NOT NULL AUTO_INCREMENT,   proj_name          VARCHAR(60),   PRIMARY KEY (id));

3、定义POJO

让我们先定义POJO,如下:

public class Employee implements Serializable {    private static final long serialVersionUID = 5892612078624312365L;    private Integer id;    private String empName;    private Integer sex;    //员工卡,一对一关联    private EmployeeCard employeeCard;    //项目,一对多关联    private List<Project> projectList;    //########setter and getter############}public class MaleEmployee extends Employee implements Serializable {    private static final long serialVersionUID = 6597520360502006892L;    private List<String> prostateList;    //########setter and getter############}public class FemaleEmployee extends Employee implements Serializable {    private static final long serialVersionUID = -7565810909492919315L7;    private List<String> uterusList;    //########setter and getter############}public class EmployeeCard implements Serializable {    private static final long serialVersionUID = -7593225091990005041L;    private Integer empId;    private Integer cardNo;    //########setter and getter############}public class Project implements Serializable {    private static final long serialVersionUID = -7834541701010022018L;    private Integer id;    private String projName;    //########setter and getter############}

除了Employee外,都是很简单的POJO。Employee其实也不复杂,Employee是基类,然后通过其派生一个男性一个女性的类,也不难理解。


下面,我们将就这三种级联展开更深一层的讨论。


 




0 0
原创粉丝点击