Java EE数据访问框架技术(第三章:Mybatis多表关系映射-下)

目录

一、一对一

User类

Usercard类

​编辑mybatis中一对一结果集映射配置

UserMapper.xml

二、一对多

建表

xml

三、多对多

建表

多表关联查询

实体类

xml

总结


一、一对一

在Java中,user表的每一行数据对应一个User类的对象

user_card表的每一行数据对应一个UserCard类的对象

思考:在设计实体类User UserCard时,如何体现出User对象和UserCard对象的关系?

解决方案:

通常在****User类中设计一个UserCard属性用于表示当前User对象对应的UserCard对象

User类

Usercard类

mybatis中一对一结果集映射配置

UserMapper.xml

<resultMap id="rm1" type="User">

<!--主键-->

<id property="id" column="user_id"></id>

<!--其他属性 省略名字统一的属性-->

<result property="name" column="name"></result>

<result property="sex" column="sex"></result>

<result property="mobile" column="mobile"></result>

<result property="email" column="email"></result>

<!--复杂自定义引用数据类型映射-->

<association property="userCard" javaType="UserCard">

<!--主键-->

<id property="id" column="c_id"></id>

<!--其他属性-->

<result property="birthday" javaType="java.util.Date"

column="birthday" jdbcType="DATE"

></result>

<result property="nationnality" column="nationnality"></result>

<result property="idcard" column="idcard"></result>

<result property="issued" column="issued"></result>

<result property="expireBegin" javaType="java.util.Date"

column="expire_begin" jdbcType="DATE"></result>

<result property="expireEnd" javaType="java.util.Date"

column="expire_end" jdbcType="DATE"></result>

</association>

</resultMap>

二、一对多

一对多在业务需求中应用非常广泛,例如一个用户对应多个订单,一个订单对应多个商品,一个部门对应多个员工等

案例:

一个班级对应多个学生

班级:t_classes

id(班级编号),name(班级名称)

学生:t_students

id(学号),name(学生姓名),sex(性别),idcard(身份证号码)
班级:t_classes

id(班级编号),name(班级名称)

学生:t_students

id(学号),name(学生姓名),sex(性别),idcard(身份证号码),c_id(班级编号)

一对多表关系中,在多的表中建立一的编号作为数据的关联关系

建表

xml

三、多对多

多对多表映射关系在实际应用中非常常见,例如:

老师和学生

教室和学生

订单和商品

一个老师对应多个学生

一个学生对应多个老师

学生表:t_students

id(学号) name (姓名) sex(性别) idcard(身份证号码)

c_id(班级编号)

教师表:t_teacher

id(教师编号) name(姓名) sex(性别) mobile(手机号码)

第三张表(中间表),为了存储学生和老师的映射关系

t_student_teacher

sid(学生编号) tid(教师编号)

建表

多表关联查询

三表关联查询:

select 表名.列名1,表名.列名2,...

from 表名1 别名1 left join 表名2 别名2 on 表1和表2的连接条件

left join 表名3 别名3 on 和表3的连接条件

例如:

#查询所有学生及其对应的老师的信息

select s.id s_id,s.name s_name,s.sex s_sex,s.idcard s_idcard,

t.id t_id,t.name t_name,t.sex t_sex,t.mobile t_mobile

from t_students s LEFT JOIN t_student_teacher st on s.id=st.sid

LEFT JOIN t_teacher t on st.tid=t.id

#查询所有老师及其对应的学生的信息

select s.id s_id,s.name s_name,s.sex s_sex,s.idcard s_idcard,

t.id t_id,t.name t_name,t.sex t_sex,t.mobile t_mobile

from t_teacher t LEFT JOIN t_student_teacher st on t.id=st.tid

LEFT JOIN t_students s on st.sid=s.id

实体类

xml

总结

表设计:

一对一:在任意表中定义一个列关联另一个表的主键

一对多:在多的一方表中定义一个列关联另一个表的主键

多对多:定义中间表 包含两个表的主键列

多表关联查询sql:

内连接 inner join 左外连接 left join 右外连接 right join

实体类:

一对一(定义实体类类型属性)

一对多(定义实体类集合类型属性)

mybatis手动映射结果集实现:

一对一(association标签映射)

一对多(collection标签映射)

相关推荐
什么都不会的Tristan41 分钟前
MybatisPlus-快速入门
java·开发语言
无心水41 分钟前
【分布式利器:腾讯TSF】2、腾讯微服务框架TSF实战指南:Spring Boot零侵入接入与容器化部署全流程
java·spring boot·分布式·微服务·springcloud·分布式利器·腾讯tsf
sxlishaobin1 小时前
设计模式之享元模式
java·设计模式·享元模式
黎明晓月1 小时前
Redis容器化(Docker)
java·redis·docker
Wpa.wk1 小时前
接口自动化测试 - REST-assure小练习(Java版-分层)
java·开发语言·经验分享·python·自动化·接口自动化·po
予枫的编程笔记1 小时前
深度解析Logstash与Beats:Elastic Stack数据采集处理双核心
java·elasticsearch·logstash·beats
qq_12498707531 小时前
基于Java的游泳馆管理系统(源码+论文+部署+安装)
java·开发语言·毕业设计·springboot·计算机毕业设计
m0_598177231 小时前
MYSQL开发- (1)
android·java·mysql
郑州光合科技余经理1 小时前
从国内到海外:同城o2o本地生活服务平台国际化实战
java·开发语言·javascript·mysql·uni-app·php·生活
摇滚侠1 小时前
30分钟正则表达式教程
java