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标签映射)

相关推荐
哲-哲14 分钟前
WVP+ZLM搭建碰到问题
java
编程彩机16 分钟前
互联网大厂Java面试:从Spring Cloud到分布式事务的技术场景解析
java·spring cloud·微服务·消息队列·分布式事务
黎雁·泠崖18 分钟前
Java内部类与匿名内部类:定义+类型+实战应用
java·开发语言
青槿吖24 分钟前
第二篇:JDBC进阶骚操作:防注入、事务回滚、连接池优化,一篇封神
java·开发语言·jvm·算法·自动化
青&棠27 分钟前
JDK 多版本管理工具 jvms
java
FITA阿泽要努力32 分钟前
Agent Engineer-Day 1 初始智能体与大语言模型基础
java·前端·javascript
2601_9498683634 分钟前
Flutter for OpenHarmony 电子合同签署App实战 - 数据持久化实现
java·数据库·flutter
码农阿豪40 分钟前
基于Milvus与混合检索的云厂商文档智能问答系统:Java SpringBoot全栈实现
java·spring boot·milvus
阿蒙Amon42 分钟前
C#每日面试题-Task和Thread的区别
java·面试·c#
索荣荣1 小时前
Java异步编程终极实战指南
java·开发语言