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

相关推荐
怀旧诚子1 小时前
timeshift之Fedora43设置,已在VM虚拟机验证,待真机验证。
java·服务器·数据库
1104.北光c°1 小时前
滑动窗口HotKey探测机制:让你的缓存TTL更智能
java·开发语言·笔记·程序人生·算法·滑动窗口·hotkey
云原生指北4 小时前
GitHub Copilot SDK 入门:五分钟构建你的第一个 AI Agent
java
Leinwin8 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
薛定谔的悦8 小时前
MQTT通信协议业务层实现的完整开发流程
java·后端·mqtt·struts
enjoy嚣士9 小时前
springboot之Exel工具类
java·spring boot·后端·easyexcel·excel工具类
罗超驿9 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
盐水冰10 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
凸头10 小时前
CompletableFuture 与 Future 对比与实战示例
java·开发语言
wuqingshun31415910 小时前
线程安全需要保证几个基本特征
java·开发语言·jvm