Python 官方文档:入门教程 => 点击学习
目录前言表连接查询一对一关系一对多关系多对多关系前言 上篇博文把基础部分记录了,本篇是对 表连接查询 中一对一,一对多,多对多关系写法区别的记录总结。 表连接查询 前提最少是两张表,
上篇博文把基础部分记录了,本篇是对 表连接查询 中一对一,一对多,多对多关系写法区别的记录总结。
前提最少是两张表,其中的子表设有外键
按对应关系可分为:
对于主外键的关系搞不清楚的可以参考我以往的博文:Mysql一点通
有如下两张表格,t_people(人)与t_passport(护照):
一个人对应一本护照,同时一本护照对应一个人,而且人不一定有护照,有护照一定会有人存在。
因此外键应设在护照表中,那么就该创建类了:
// Passport:
public class Passport {
private Integer passportId;
private String passportSerial;
}
// People
public class People {
private Integer peopleId;
private String peopleName;
private Passport passport;
}
这样创建非常符合表之间的逻辑关系,但是创建方式并不唯一。
在Passport类中添加People属性也是可以的,即:
// Passport
public class Passport {
private Integer passportId;
private String passportSerial;
private People people;
}
// People
public class People {
private Integer peopleId;
private String peopleName;
}
那实际做项目时应该如何取舍?答案是根据需求:
这里以查询公民以及其对应的护照信息为例,编写项目:
在mapper接口定义方法:
public interface PeopleMapper {
List<People> selectAll();
}
在xml中编写sql:
<mapper namespace="com.qj.mapper.PeopleMapper">
<resultMap id="peopleMap" type="People">
<id property="peopleId" column="people_id"/>
<result property="peopleName" column="people_name"/>
<association property="passport" javaType="Passport">
<id property="passportId" column="passport_id"/>
<result property="passportSerial" column="passport_serial"/>
</association>
</resultMap>
<select id="selectAll" resultMap="peopleMap">
select *
from t_people t1
left join t_passport t2 on t1.people_id = t2.people_id
</select>
</mapper>
重点在于resultMap里的写法:
association 标签用于一对一关系:
编写测试类:
public static void main(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(订单):
用户可以下多个订单,一个订单对应一个用户,这就是一种一对多关系。
查询用户及其所有订单信息:
// Order
public class Order {
private Integer orderId;
private String orderName;
}
// User
public class User {
private Integer uId;
private String userName;
private String userPwd;
private List<Order> orders;
}
xml文件的写法:
<mapper namespace="com.qj.mapper.UserMapper">
<resultMap id="userMap" type="User">
<id property="uId" column="u_id"/>
<result property="userName" column="u_username"/>
<result property="userPwd" column="u_pwd"/>
<collection property="orders" javaType="java.util.List" ofType="Order">
<id property="orderId" column="order_id"/>
<result property="orderName" column="order_name"/>
</collection>
</resultMap>
<select id="selectAll" resultMap="userMap">
select *
from t_user t1
left join t_order t2
on t1.u_id = t2.user_id
</select>
</mapper>
这里与一对一的区别就在于使用的标签不同:
collection 标签:
测试结果:
有以下三张表格,表示了学生的选课情况:
一个学生可以选多个课程,而一个课程可以被多个学生选择,这就是典型的多对多关系。
而 多对多 与 一对多 关系在xml文件中resultMap的写法几乎一致,因此不做过多解释,看一下sql 语句与测试结果即可:
<select id="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实现表连接查询写法(三种对应关系)的方法总结的文章就介绍到这了,更多相关MyBatis表连接查询内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: MyBatis实现表连接查询写法(三种对应关系)的方法总结
本文链接: https://lsjlt.com/news/178468.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0