您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

Mybatis框架实现一对多查询两种不同的实现方式

时间:2021-06-04 15:00:53  来源:今日头条  作者:正义的板栗君
Mybatis框架实现一对多查询两种不同的实现方式

 

在上篇文章分享了MyBatis框架实现了一对一查询操作,但是在开发中一对多查询操作更为常用。其实在平时生活中一对多关系就有很多,就比如一个部门下面可以有多个员工,而其中的一个员工也属于一个部门等等。

接下来我们就来学习一下如何在项目中实现一对多的查询操作呢。

一对多查询与上一篇一对一查询的方式一致,但不同的是在mApper配置文件中一对一查询使用的是association标签,而一对多查询使用的是collection标签。

这里以部门和员工为例讲解一对多级联查询操作,一个部门下面关联着多个员工。

创建两张数据表,一个是部门表,一个是员工表,这两张表具有一对多的关联关系,在员工表添加外键dept_id字段去关联部门表的主键dept_id字段。

t_dept 部门表

Mybatis框架实现一对多查询两种不同的实现方式

 

t_employee 员工表

Mybatis框架实现一对多查询两种不同的实现方式

 

创建两张表对应的实体bean类。

Dept部门类

Mybatis框架实现一对多查询两种不同的实现方式

 


Mybatis框架实现一对多查询两种不同的实现方式

 

Employee员工类

Mybatis框架实现一对多查询两种不同的实现方式

 


Mybatis框架实现一对多查询两种不同的实现方式

 

现在让我们看看如何获取部门信息以及其所对应的员工列表信息。

其实和一对一映射一样,我们可以两种方式实现,分别是嵌套结果和分步查询两种方式,都可以实现一对多映射查询。

1.嵌套结果,执行一个SQL语句(类似于MySQL的连接查询)

我们可以使用嵌套结果resultMap方式获得部门及其员工信息,代码如下:

创建DeptMapper.xml配置文件,代码如下:

Mybatis框架实现一对多查询两种不同的实现方式

 


Mybatis框架实现一对多查询两种不同的实现方式

 

在mapper配置文件中,<collection>元素是用来将多行员工结果映射成一个部门Dept对象的一个List集合中。

创建数据操作接口DeptMapper,并在接口中定义getDeptInfo方法。

Mybatis框架实现一对多查询两种不同的实现方式

 

创建调用数据接口的DeptService类。

Mybatis框架实现一对多查询两种不同的实现方式

 

创建DeptOperTest测试类并测试。

Mybatis框架实现一对多查询两种不同的实现方式

 

junit测试之后输出的结果:

Mybatis框架实现一对多查询两种不同的实现方式

 


Mybatis框架实现一对多查询两种不同的实现方式

 

2.分步查询,执行两个select查询语句(类似于mysql的子查询)

我们可以使用嵌套Select语句方式获得部门及其员工信息,代码如下:

创建DeptMapper.xml配置文件

Mybatis框架实现一对多查询两种不同的实现方式

 


Mybatis框架实现一对多查询两种不同的实现方式

 

创建DeptMapper接口

Mybatis框架实现一对多查询两种不同的实现方式

 

创建DeptService类

Mybatis框架实现一对多查询两种不同的实现方式

 


Mybatis框架实现一对多查询两种不同的实现方式

 

创建DeptOperTest测试类

Mybatis框架实现一对多查询两种不同的实现方式

 

测试之后输出的结果:

Mybatis框架实现一对多查询两种不同的实现方式

 

注意:部门表和员工表的主键id字段名要唯一,例如不能都写id,如果一样的话,在查询的时候就会出现,关联查询出来的员工数据只有一条记录,查不到部门对应下面的所有员工。我之前就是将两张表的主键id字段名都写为id,导致测试结果查询出来的员工数据只有一条的情况。

好了,今天的分享就到这里了,希望对大家的学习有所帮助,也可以在下面留言交流。



Tags:Mybatis框架   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
在上篇文章分享了Mybatis框架实现了一对一查询操作,但是在开发中一对多查询操作更为常用。其实在平时生活中一对多关系就有很多,就比如一个部门下面可以有多个员工,而其中的一...【详细内容】
2021-06-04  Tags: Mybatis框架  点击:(181)  评论:(0)  加入收藏
▌简易百科推荐
本篇文章主要介绍了使用MyBatis框架完成数据库的增、删、改、查操作。准备工作运行schema.sql和data.sql脚本文件中的 SQL 语句创建t_user表并添加部分测试数据。schema.sql...【详细内容】
2022-07-15  嗨皮汪小成    Tags:MyBatis   点击:(0)  评论:(0)  加入收藏
1 Hive基本概念Hive是一个构建在Hadoop上的数据仓库框架。最初,Hive是由Facebook开发,后来移交由Apache软件基金会开发,并作为一个Apache开源项目。Hive是基于Hadoop的一个数据...【详细内容】
2022-07-15  秃头Java人    Tags:Hive   点击:(2)  评论:(0)  加入收藏
今天给大家讲讲 SpringBoot 框架 整合 Elasticsearch 实现海量级数据搜索。一、简介在上篇ElasticSearch 文章中,我们详细的介绍了 ElasticSearch 的各种 api 使用。实际的项...【详细内容】
2022-07-15  java小悠    Tags: Elasticsearch   点击:(3)  评论:(0)  加入收藏
SpringBoot开发Restful接口,有什么API规范吗?如何快速生成API文档呢?Swagger 是一个用于生成、描述和调用 RESTful 接口的 Web 服务。通俗的来讲,Swagger 就是将项目中所有(想要...【详细内容】
2022-07-14  Java全栈知识体系    Tags:Swagger   点击:(2)  评论:(0)  加入收藏
一、部署准备安装数据库、jdk、nginx、域名证书1、下载 nginx,官方网址如下:http://nginx.org/en/download.html2、解压安装包到任意目录 如:G:\nginx二、前端部署1、打开前端...【详细内容】
2022-07-14  智慧魔法豆浆    Tags:vue   点击:(2)  评论:(0)  加入收藏
SpringBoot 内置支持的 Web 容器有 Tomcat、Undertow、Jetty 和 Netty。默认情况下,这些 Web 服务的 AccessLog 日志是不开启的,而 AccessLog 日志对于做接口统计尤为重要。如...【详细内容】
2022-07-13  BUG弄潮儿    Tags:AccessLog 日志   点击:(10)  评论:(0)  加入收藏
什么是Starterstarter 是springboot 的核心,每个starter负责实现特定的功能,使用者只需引入starter即可自动配置,无需关心框架整合带来的问题。Starter 项目结构src |- main...【详细内容】
2022-07-12  IT食者    Tags:SpringBoot   点击:(9)  评论:(0)  加入收藏
mybaits非必填项处理数据库表字段khzjyxqx为日期型,非必填, 前台页面如下: 后台mybaits处理如下: 如果不处理,当为空时khzjyxqx=&#39;&#39;时会报错。<update id="updatesave" pa...【详细内容】
2022-07-11  在水一方357159258    Tags:mybaits   点击:(10)  评论:(0)  加入收藏
关于过气网红编程语言 Ruby,我们此前曾发过一篇文章去回顾其大受追捧的过往,并讨论了它每况愈下的生存状态。不过人气并不能直接说明语言质量差,一方面 Ruby on Rails(用 Ruby...【详细内容】
2022-07-08  InfoQ    Tags: Web 框架   点击:(9)  评论:(0)  加入收藏
1、JWT的构成- 头部(header):描述该JWT的最基本的信息,如类型以及签名所用的算法。- 负载(payload):存放有效信息的地方。- 签证(signature):base64加密后的header、base64加...【详细内容】
2022-07-08  dream19    Tags:SpringBoot   点击:(10)  评论:(0)  加入收藏
相关文章
    无相关信息
站内最新
站内热门
站内头条