目录
一、一对一
在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_classesid(班级编号),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标签映射)