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
- MyBatis级联探讨第一篇——概念和模型
- MyBatis级联探讨第三篇——一对一和一对多
- MyBatis级联探讨第二篇——鉴别器(discriminator)
- MyBatis级联第四篇——N+1问题和全局延迟加载【推荐,MyBatis级联重要的一篇原创,建议认真读】
- MyBATIS插件原理第一篇——技术基础(反射和JDK动态代理)
- HTTP/2探索第一篇——概念
- 数据库概念设计模型探讨
- 第一篇 :概念理解
- mybatis第一篇
- 机器学习第一篇(stanford大学公开课学习笔记) —机器学习的概念和梯度下降
- 算法第一篇之概念
- 分布式系统概念--第一篇 一致性协议、一致性模型、拜占庭问题、租约、副本协议
- 第一篇—开端
- mybatis 学习记录(4.1)—— 级联查询(无 association 和 collection)
- mybatis 学习记录(4.2)—— 级联查询(有 association 和 collection)
- ASP.NET 数据分页第一篇—探讨分页原理及 SQL Server 2005 的 ROW_NUMBER 函数
- WinSocket模型的探讨——漫谈
- WinSocket模型的探讨——漫谈
- intellIJ配置javaweb服务器
- Python学习笔记(七)
- 模拟实现auto_ptr、scoped_ptr、shared_ptr等智能指针
- sql联合查询(内联、左联、右联、全联)
- 两种方式解决jquery Ajax 发送中文乱码的方法,
- MyBatis级联探讨第一篇——概念和模型
- 算法复习——背包DP问题
- 工作中最全最常用的正则表达式
- 安装intelhaxm-android.exe时,屏幕一闪而过
- 打开方式中设置默认打开方式时,选择的程序不会出现到设置默认方式的编辑框中的解决方法
- JAVA中Action层, Service层 ,modle层 和 Dao层的功能区分
- 241. Different Ways to Add Parentheses
- ScrollView嵌套可以水平滚动的自定义控件时滑动事件冲突问题解决办法
- 第1章 操作系统的导论