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

相关推荐
c++之路2 小时前
C++23概述
java·c++·c++23
专注API从业者3 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
摇滚侠3 小时前
DBeaver 导入数据库 导入 SQL 文件 MySQL 备份恢复
java·数据库·mysql
keep one's resolveY3 小时前
SpringBoot实现重试机制的四种方案
java·spring boot·后端
天空属于哈夫克34 小时前
企业微信API常见的错误和解决方案
java·数据库·企业微信
摇滚侠5 小时前
VMvare 虚拟机 Oracle19c 安装步骤,远程连接 Oracle19c,百度网盘安装包
java·oracle
梁萌5 小时前
idea报错找不到XX包的解决方法
java·intellij-idea·启动报错·缺少包
Agent产品评测局5 小时前
生产排期与MES/ERP系统打通,实操方法详解 —— 2026企业级智能体自动化选型与实战指南
java·运维·人工智能·ai·chatgpt·自动化
阿丰资源5 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
呱牛do it5 小时前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 8)
java