关于我们

质量为本、客户为根、勇于拼搏、务实创新

< 返回新闻公共列表

MyBatis 表连接查询写法|三种对应关系

发布时间:2023-06-28 10:00:50
前言 上篇博文把基础部分记录了,本篇是对 表连接查询 中一对一,一对多,多对多关系写法区别的记录总结。 表连接查询 前提最少是两张表,其中的子表设有外键 按对应关系可分为: 一对一 一对多 多对多 对于主外键的关系搞不清楚的可以参考我以往的博文: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 selectAll(); } 在xml中编写sql: 重点在于resultMap里的写法: association 标签用于一对一关系: propetry 后写属性名 javaType 后写该属性所属类的类型 编写测试类: 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 orders; } xml文件的写法: 这里与一对一的区别就在于使用的标签不同: collection 标签: property后写属性名 javaType后写集合类型 ofType后写泛型的类型 测试结果: 多对多关系 有以下三张表格,表示了学生的选课情况: 一个学生可以选多个课程,而一个课程可以被多个学生选择,这就是典型的多对多关系。 而 多对多 与 一对多 关系在xml文件中resultMap的写法几乎一致,因此不做过多解释,看一下sql 语句与测试结果即可: 下篇总结 mybatis 动态sql、常用的标签以及缓存的有关知识,需要的小伙伴记得订阅专栏。

/template/Home/leiyu/PC/Static