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 小时前
基于语义切分 vs 基于结构切分的实际差异
java·开发语言·数据库·安全·batch
寻星探路6 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
曹牧8 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
爬山算法9 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty7259 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎9 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄9 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿9 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds10 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化