mybatis的一对多,多对一,以及多对多的配置和使用

news/2024/10/21 13:21:48
 
 
根据这个应用场景,我们需要获取在查询一个用户信息的时候还要去读取这个用户发布的帖子
现在我们来看一看用户级联文章在JavaBean中的编写方式,这就是一对多在JavaBean中的配置
现在我们再来看一看Mybatis的Mapper该如何编写一对多?很简单,就是在resultMap标签中配置<collection>标签,用来存储查询到的文章列表,注意posts代表的是用户实体的文章List集合
这样Sql查询到的内容就映射到User用户实体中的属性中啦,这就是一对多的查询
 
3.现在我们再来探究一下Mybatis的多对一,现在有一个需求如下
现在我们来看一看文章级联用户在JavaBean中的编写方式,这是多对一在JavaBean中的配置
现在我们再来看一看Mybatis的Mapper该如何编写多对一?很简单,就是在resultMap标签中配置<association></association>标签关联所属的用户实体
 
 
4.最后我们来探究一下Mybatis的多对多,在很多时候我们较好的运用多对多可以处理很多现实的逻辑问题,比如现在我们有下面这样一个需求
 
当前,一个用户可以拥有多个组,一个组也可以拥有多个用户,这样的关系就是多对多,为了解决这个问题,我们需要再用户和组之间建立一张关联的表,用于存储他们之间的对应关系,用户和组都通过这个关联的表,来查询他们之间的关系
 
现在我我们先来看一看这个关联对象的JavaBean和其Mybatis的Mapper文件是怎么样的
首先是JavaBean

 

再来看看这个实体对应的Mapper文件,只有两个功能
 
 
现在我们开始来看我们的主角Users用户和Group组这两位的JavaBean和Mapper文件时怎么写的
 
先看Users(用户实体)

 

Users的Mapper
这样查询到的的User对用户象就是这样的,把这个用户所对应的组都查了出来
Users{id=0, username='yiibai', mobile='13838009988', groups=[Group{groupId=1, groupName='Group-1', users=null}, Group{groupId=2, groupName='Group-2', users=null}]}
 
再来看看Group(组实体),其实就是和Users实体是一样的哈
还是看Group的JavaBean
 
再看看看Group的Mapper
这样再查询Group的时候就会把这个组的所有成员都查询出来了
Group{groupId=0, groupName='Group-1', users=[Users{id=1, username='yiibai', mobile='13838009988', groups=null}, Users{id=2, username='User-name-1', mobile='13838009988', groups=null}]}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/74151.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

PbootCMS执行SQL发生错误(DISK I/O ERROR)怎么办

执行SQL发生错误(DISK I/O ERROR)问题描述:PBootCMS网站程序提示“执行 SQL 发生错误!错误:DISK I/O ERROR”。 解决方案:检查磁盘空间:确保服务器磁盘空间充足,没有满。 检查磁盘健康:使用磁盘检测工具检查磁盘健康状况,确保没有坏道。 优化数据库:优化数据库表,修…

K个节点翻转链表

概述 起因:leetcode题目 25. K 个一组翻转链表 问题描述 给你链表的头节点 head ,每 k 个节点一组进行翻转,请你返回修改后的链表。 k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。你不能只是单纯的改变节…

PbootCMS登录后无法使用数据备份功能,备份失败或提示错误怎么办

问题描述:登录后无法使用数据备份功能,备份失败或提示错误。 解决方案:检查文件权限:确保备份目录具有可写权限。 检查数据库连接:确保数据库连接配置正确,数据库服务正常运行。 检查PHP错误日志:查看服务器的PHP错误日志,查找可能的错误信息。 清除缓存:清除浏览器缓…

一文彻底弄清Redis的布隆过滤器

布隆过滤器(Bloom Filter)是一种空间效率极高的数据结构,用于快速判断一个元素是否在集合中。它能够节省大量内存,但它有一个特点:可能存在误判,即可能会认为某个元素存在于集合中,但实际上不存在;而对于不存在的元素,它保证一定不会误判。布隆过滤器适合在对存储空间…

PbootCMS登录后无法上传文件怎么办

登录后无法上传文件问题描述:登录后无法上传文件,提示上传失败。 解决方案:检查文件权限:确保上传目录(如upload/)具有可写权限(通常为755或777)。 检查PHP配置:确保PHP的文件上传设置正确,特别是upload_max_filesize和post_max_size。 检查防火墙和安全设置:确保服…

PbootCMS登录页面无法正常加载,显示为空白页或错误信息怎么办

问题描述:登录页面无法正常加载,显示为空白页或错误信息。 解决方案:检查Web服务器配置:确保Web服务器(如Apache、Nginx)配置正确,特别是虚拟主机配置。 检查PHP配置:确保PHP配置正确,特别是php.ini文件中的设置。 检查文件权限:确保PBootCMS相关目录和文件的权限设置…

PbootCMS登录后立即被注销怎么办

登录后立即被注销问题描述:登录后立即被注销,无法保持登录状态。 解决方案:检查Cookie设置:确保浏览器的Cookie设置正确,允许PBootCMS设置Cookie。 检查会话设置:确保PHP的会话设置正确,特别是session.cookie_lifetime和session.gc_maxlifetime。 检查防火墙和安全设置:…

PbootCMS登录后页面加载缓慢怎么办

登录后页面加载缓慢问题描述:登录后页面加载速度非常慢。 解决方案:检查服务器性能:确保服务器资源(CPU、内存、磁盘I/O)充足,没有瓶颈。 优化数据库查询:检查数据库查询,优化慢查询。 启用缓存:启用PBootCMS的缓存功能,减少数据库查询次数。 检查网络带宽:确保服务…