❤️作者主页:微凉秋意
✅作者简介:后端领域优质创作者🏆,CSDN内容合伙人🏆,阿里云专家博主🏆
✨精品专栏:C++面向对象
🔥系列专栏:JavaWeb
文章目录
前言
上篇博文把基础部分记录了,本篇是对 表连接查询 中一对一,一对多,多对多关系写法区别的记录总结。
表连接查询
- 前提最少是两张表,其中的子表设有外键
- 按对应关系可分为: - 一对一- 一对多- 多对多
对于主外键的关系搞不清楚的可以参考我以往的博文:mysql一点通
一对一关系
有如下两张表格,t_people(人)与t_passport(护照):
一个人对应一本护照,同时一本护照对应一个人,而且人不一定有护照,有护照一定会有人存在。
因此外键应设在护照表中,那么就该创建类了:
// Passport:publicclassPassport{privateInteger passportId;privateString passportSerial;}// PeoplepublicclassPeople{privateInteger peopleId;privateString peopleName;privatePassport passport;}
这样创建非常符合表之间的逻辑关系,但是创建方式并不唯一。
在Passport类中添加People属性也是可以的,即:
// PassportpublicclassPassport{privateInteger passportId;privateString passportSerial;privatePeople people;}// PeoplepublicclassPeople{privateInteger peopleId;privateString peopleName;}
那实际做项目时应该如何取舍?答案是根据需求:
- 如果是查询公民以及其对应的护照信息,那就用前者
- 如果是查询所有护照以及持有者的信息,那就用后者
- 因此在设计类时不要太死板,两种方法需要斟酌后选择
这里以查询公民以及其对应的护照信息为例,编写项目:
在mapper接口定义方法:
publicinterfacePeopleMapper{List<People>selectAll();}
在xml中编写sql:
<mappernamespace="com.qj.mapper.PeopleMapper"><resultMapid="peopleMap"type="People"><idproperty="peopleId"column="people_id"/><resultproperty="peopleName"column="people_name"/><associationproperty="passport"javaType="Passport"><idproperty="passportId"column="passport_id"/><resultproperty="passportSerial"column="passport_serial"/></association></resultMap><selectid="selectAll"resultMap="peopleMap">
select *
from t_people t1
left join t_passport t2 on t1.people_id = t2.people_id
</select></mapper>
重点在于resultMap里的写法:
association
标签用于一对一关系: -propetry
后写属性名-javaType
后写该属性所属类的类型
编写测试类:
publicstaticvoidmain(String[] args){SqlSession sqlSession =MybatisUtil.getSqlSession();PeopleMapper mapper = sqlSession.getMapper(PeopleMapper.class);
mapper.selectAll().forEach(System.out::println);MybatisUtil.closeSqlSession(sqlSession);}
这段代码:
mapper.selectAll().forEach(System.out::println);
中的写法是在
JDK1.8
之后有的:
- 格式:集合.foreach(打印方法)
运行结果:
一对多关系
有如下两张表格,t_user(用户),t_order(订单):
用户可以下多个订单,一个订单对应一个用户,这就是一种一对多关系。
查询用户及其所有订单信息:
// OrderpublicclassOrder{privateInteger orderId;privateString orderName;}// UserpublicclassUser{privateInteger uId;privateString userName;privateString userPwd;privateList<Order> orders;}
xml文件的写法:
<mappernamespace="com.qj.mapper.UserMapper"><resultMapid="userMap"type="User"><idproperty="uId"column="u_id"/><resultproperty="userName"column="u_username"/><resultproperty="userPwd"column="u_pwd"/><collectionproperty="orders"javaType="java.util.List"ofType="Order"><idproperty="orderId"column="order_id"/><resultproperty="orderName"column="order_name"/></collection></resultMap><selectid="selectAll"resultMap="userMap">
select *
from t_user t1
left join t_order t2
on t1.u_id = t2.user_id
</select></mapper>
这里与一对一的区别就在于使用的标签不同:
collection
标签: -property
后写属性名-javaType
后写集合类型-ofType
后写泛型的类型
测试结果:
多对多关系
有以下三张表格,表示了学生的选课情况:
一个学生可以选多个课程,而一个课程可以被多个学生选择,这就是典型的多对多关系。
而 多对多 与 一对多 关系在xml文件中
resultMap
的写法几乎一致,因此不做过多解释,看一下sql 语句与测试结果即可:
<selectid="selectAll"resultMap="stuMap">
select *
from t_stu t1
left join t_sc t2 on t1.stu_id = t2.s_id
left join t_course t3 on t3.course_id = t2.c_id
</select>
下篇总结
mybatis
动态sql、常用的标签以及缓存的有关知识,需要的小伙伴记得订阅专栏。
版权归原作者 庚昀◟ 所有, 如有侵权,请联系我们删除。