spring同一个接口如何分页实现主表或主+联表group by查询
1 需求背景
我们的上游系统想要知道主表的记录关联子表所有记录中是否有一条满足特定的条件,如果有满足的就返回主表中的id。比如品牌brand主表中id为10的记录,在子表brand_rel中有id为1,2,3,4的这四个记录,其中1,2所在记录的status字段值满足等于0,那么就可以返回10给调用方。
其次这个查询功能是要做在原来的查询接口中的,旧接口只允许匹配针对主表的条件进行分页查询。
2 需求分析
2.1 如何兼容旧功能
通过在入参的请求体中新增一个子表的查询字段,后端拿到请求体会先判断子表的这个字段是否为空,如果为空则走旧有的查询条件,否则走新的查询分支。
2.2 联表查询,一个主表的记录会匹配到多个子表的记录,需要去重。
使用group by关键字对主表的id进行去重。
2.3 量很大时,需要分页
使用合理的分页插件。
3 实现
3.1 需求背景和分析
- 主表 brand 记录与子表 brand_rel 记录有一对多的关系。
- 新增一个子表查询字段来扩展旧接口。
- 使用 GROUP BY 去重主表记录。
- 使用分页插件实现数据的分页。
为了实现这一需求,假设我们在使用 Spring Boot 框架和 MyBatis-Plus 分页插件。
3.2 数据库表结构
-- 主表 brand
CREATE TABLE brand (id BIGINT PRIMARY KEY,name VARCHAR(100)
);-- 子表 brand_rel
CREATE TABLE brand_rel (id BIGINT PRIMARY KEY,brand_id BIGINT,status INT,FOREIGN KEY (brand_id) REFERENCES brand(id)
);
3.3 SQL 查询语句
为了得到符合条件的主表 brand ID 列表,SQL 查询如下:
SELECT b.id
FROM brand b
JOIN brand_rel br ON b.id = br.brand_id
WHERE br.status = 0
GROUP BY b.id
LIMIT #{offset}, #{pageSize};
3.4 Controller 和 Service 层实现
以下提供一个简单的 Spring Boot Controller 和 Service 实现。
3.4.1 请求体对象
public class BrandQueryRequest {private String mainTableCondition; // 主表的查询条件,可以扩展private String subTableCondition; // 子表的查询条件,比如 "br.status = 0"private int offset;private int pageSize;// getters and setters
}
3.4.2 Controller
@RestController
@RequestMapping("/api/brands")
public class BrandController {@Autowiredprivate BrandService brandService;@PostMapping("/query")public ResponseEntity<List<Long>> queryBrands(@RequestBody BrandQueryRequest request) {List<Long> result = brandService.queryBrandIds(request);return ResponseEntity.ok(result);}
}
3.4.3 Service
@Service
public class BrandService {@Autowiredprivate BrandMapper brandMapper;public List<Long> queryBrandIds(BrandQueryRequest request) {if (request.getSubTableCondition() == null) {// 走旧查询逻辑return brandMapper.queryBrandsByMainCondition(request.getMainTableCondition(), request.getOffset(), request.getPageSize());} else {// 新的查询逻辑return brandMapper.queryBrandsBySubCondition(request.getSubTableCondition(), request.getOffset(), request.getPageSize());}}
}
3.4.4 Mapper
利用 MyBatis-Plus,定义一个自定义的 SQL 查询方法:
@Mapper
public interface BrandMapper {@Select("<script>" +"SELECT b.id " +"FROM brand b " +"<where>" +" <if test='mainTableCondition != null'>AND ${mainTableCondition}</if> " +"</where>" +"GROUP BY b.id " +"LIMIT #{offset}, #{pageSize}" +"</script>")List<Long> queryBrandsByMainCondition(@Param("mainTableCondition") String mainTableCondition, @Param("offset") int offset, @Param("pageSize") int pageSize);@Select("<script>" +"SELECT b.id " +"FROM brand b " +"JOIN brand_rel br ON b.id = br.brand_id " +"<where>" +" <if test='subTableCondition != null'>AND ${subTableCondition}</if> " +"</where>" +"GROUP BY b.id " +"LIMIT #{offset}, #{pageSize}" +"</script>")List<Long> queryBrandsBySubCondition(@Param("subTableCondition") String subTableCondition, @Param("offset") int offset, @Param("pageSize") int pageSize);
}
3.4.5 总结
这样,我们就成功地实现了一个能够兼容旧功能并支持新功能的查询接口。通过在请求体中新增一个子表的查询字段来扩展逻辑,确保最大限度的代码复用和功能扩展。
相关文章:
spring同一个接口如何分页实现主表或主+联表group by查询
1 需求背景 我们的上游系统想要知道主表的记录关联子表所有记录中是否有一条满足特定的条件,如果有满足的就返回主表中的id。比如品牌brand主表中id为10的记录,在子表brand_rel中有id为1,2,3,4的这四个记录࿰…...
SpringDataJpa源码分析
我们在定义Repository的时候通常定义的时一个接口,而并没有去实现这个接口,那么Jpa是如何让开发者无需自己实现接口就可以使用Repository去操作数据库? 动态代理!!! Repository原理 试想一下JPA是如何做的…...
卷积神经网络 - 卷积神经网络与深度学习的历史篇
序言 卷积神经网络( Convolutional Neural Networks, CNN \text{Convolutional Neural Networks, CNN} Convolutional Neural Networks, CNN)与深度学习作为人工智能领域的两大重要分支,其发展历程充满了探索与突破。深度学习,作…...
初识 Floodfall 算法
文章目录 **一、Floodfall 算法的概述****二、深度优先搜索(DFS)和广度优先搜索(BFS)在 Floodfall 算法中的应用****三、算法的基本原理****四、应用场景** 一、Floodfall 算法的概述 Floodfall 算法通常用于解决与区域填充、图的…...
[Linux] LVM挂载的硬盘重启就掉的问题解决
问题:系统重启后挂在逻辑卷的盘会掉(必现) 环境:SUSE Linux 11 SP4 原因:boot.lvm是关闭的 解决:boot.lvm设置开启 参考资料: linux下lvm状态Not avaliable问题排查及处理(常见Suse操作系统…...
YOLOv8改进 | 主干网络 | 用EfficientNet卷积替换backbone【教程+代码 】
秋招面试专栏推荐 :深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 💡💡💡本专栏所有程序均经过测试,可成功执行💡💡💡 专栏目录 :《YOLOv8改进有效涨点》专栏介绍 & 专栏目录 | 目前已有80+篇内容,内含各种Head检测头、损失函数Loss、…...
数据库规范化设计 5大基本原则
规范化设计原则是数据库设计的基本原则,有助于减少数据冗余,提高数据一致性和完整性,简化数据管理,增强数据安全性,对整个开发项目至关重要。而缺乏规范化设计会导致数据冗余,增加存储成本,引发…...
【nginx】解决k8s中部署nginx转发不会自动更新域名解析启动失败的问题
文章目录 1. 问题2.解决办法3.扩展说明3.1 DNS解析阶段划分3.2 问题说明3.2.1 先看/etc/resolv.conf说明3.2.2 针对第一个问题3.2.3 针对第二个问题 【后端】NginxluaOpenResty高性能实践 参考: https://blog.csdn.net/u010837612/article/details/123275026 1. 问…...
LeetCode637 二叉树的层平均值
前言 题目: 637. 二叉树的层平均值 文档: 代码随想录——二叉树的层平均值 编程语言: C 解题状态: 求取平均值的时候出现了点问题 思路 C中,浮点数的相加会产生精度误差,求取平均值时最好只在最后一步进行…...
王学岗ASM
服务发现 package com.example.testasm;import android.content.Context; import android.os.Bundle;import androidx.activity.EdgeToEdge; import androidx.appcompat.app.AppCompatActivity; import androidx.core.graphics.Insets; import androidx.core.view.ViewCompat;…...
【数据结构】—— 队列
1、队列的概念2、队列的结构如何选择合适的数据结构实现队列(数组or链表) 3、队列的链式存储3.1 队列的链式存储结构3.2 队列的常见接口3.3 队列的接口实现初始化判空入队列出队列获取队头元素获取队尾元素获取节点个数销毁 3.4 源代码 4、队列的顺序存储…...
vue中openlayers过滤高亮显示某个图层
vue中openlayers过滤高亮显示某个图层 openlayers库没有直接支持这样设置,所以可以使用库:ol-ext,地址:https://viglino.github.io/ol-ext/examples/filter/map.filter.crop.html 效果: 关键代码: /**…...
WPF篇(11)-ToolTip控件(提示工具)+Popup弹出窗口
ToolTip控件 ToolTip控件继承于ContentControl,它不能有逻辑或视觉父级,意思是说它不能以控件的形式实例化,它必须依附于某个控件。因为它的功能被设计成提示信息,当鼠标移动到某个控件上方时,悬停一会儿,…...
【mysql 第一篇章】系统和数据库的交互方法
一、宏观的查看系统怎么和数据库交互 在我们刚刚接触系统和数据库的时候不明白其中的原理,只知道系统和数据库是需要交互的。所以我们会理解成上图的形式。 二、MYSQL 驱动 随着我们的学习时间的加长以及对程序的了解,发现链接数据库是需要有别的工具辅…...
数据结构-位运算总结
位运算总结: 1.求位1的个数 191. 位1的个数 - 力扣(LeetCode) 有两种写法: 1.是把该数不断的去与0x1相与,得到该数的最后一位的值,然后判断他是不是1,再把该数更新一下整体往后移动一位也就…...
java 异常堆栈的由来
编写的程序代码内部错误产生的异常,如调用对象为空(空指针异常)、数组越界异常、除0异常等。这种通常称为未检查的异常(Runtime异常子类),在虚拟机中执行时会集中处理这些异常。其他运行中异常,通过throw语句主动抛出的…...
【推荐系统】【多任务学习】Progressive Layered Extraction (PLE)
Progressive Layered Extraction (PLE): A Novel Multi-Task Learning (MTL) Model for Personalized Recommendations 文章目录 Progressive Layered Extraction (PLE): A Novel Multi-Task Learning (MTL) Model for Personalized Recommendations1 论文出处2 背景2.1 背景介…...
java -转win32/win64免安装jre环境运行
由于java 转为exe,只能在装有JDK环境的电脑运行, 发给其他人也不能运行,缺少环境,程序自己背着jre走 1.先打好jar 包 2.使用exe4j 把jar包转成exe 运行程序 3.使用inno stup ,把exe运行程序加上jre环境 以下是具体实现…...
算法板子:容斥原理——求出 1∼n 中能被质数 p1,p2,…,pm 中的至少一个数整除的整数有多少个
1. 题目要点 1. 设:求1~10中能被质数2和3中至少一个数整除的数有多少个。1~10中能被质数2整除的数的集合记为S1{2,4,6,8,10},能被质数3整除的数的集合记为S2{3,6,9},能同时被质数2和3整数的数的集合为S1∩S2{6} 2. 这道题的目的是求S1∪S2∪S…...
用gurobipy求解带不等式约束条件的优化问题
1. 引入 在当今的数据驱动世界中,优化问题无处不在,从工程设计到经济模型,再到机器学习算法的调参,优化都是实现效率最大化、成本最小化或性能最优化的关键工具。 这里有一个典型的数学优化问题,目标是在给定的约束条…...
Qwen3.5-9B-AWQ-4bit开源模型价值解析:为何选择AWQ-4bit而非GGUF或GPTQ
Qwen3.5-9B-AWQ-4bit开源模型价值解析:为何选择AWQ-4bit而非GGUF或GPTQ 1. 模型核心能力解析 1.1 多模态理解能力 Qwen3.5-9B-AWQ-4bit是一个支持图像与文本联合理解的多模态模型,其核心能力体现在: 视觉-语言联合处理:能够同…...
别再瞎调RAG了!用RAGAS给你的LangChain应用做个“体检报告”(附完整代码)
用RAGAS为你的LangChain应用做深度诊断:从指标解读到精准优化 当你花费数周构建的RAG系统突然在关键演示中输出"纽约市得名于一位爱吃苹果的市长"时,那种绝望感我深有体会。去年我们的客服机器人就曾把"产品退货政策"解释成"建…...
手柄映射的艺术:RetroArch输入系统深度解析与实战指南
手柄映射的艺术:RetroArch输入系统深度解析与实战指南 【免费下载链接】RetroArch Cross-platform, sophisticated frontend for the libretro API. Licensed GPLv3. 项目地址: https://gitcode.com/GitHub_Trending/re/RetroArch 问题发现:当手柄…...
BiliTools:5分钟学会高效管理你的B站学习资源
BiliTools:5分钟学会高效管理你的B站学习资源 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持下载视频、番剧等等各类资源 项目地址: https://gitcode.com/GitHub_Trending/bilit/BiliTools 你是否曾经…...
Agent RAG 底层核心难点
Agent 1. 任务规划与拆解 (Reasoning & Decomposition) 递归深度失控:任务拆得太细导致逻辑迷失,或拆得太粗无法执行。目标漂移 (Goal Drift):长流程中 Agent 忘记了最初的最终目标。不可逆决策风险:在缺乏“回滚”机制的现实…...
Path of Building PoE2:流放之路2终极角色规划器完整指南
Path of Building PoE2:流放之路2终极角色规划器完整指南 【免费下载链接】PathOfBuilding-PoE2 项目地址: https://gitcode.com/GitHub_Trending/pa/PathOfBuilding-PoE2 还在为《流放之路2》复杂的角色构建而头疼吗?每次天赋加点都犹豫不决&am…...
效率利器:用快马平台快速打造openclaw-zero-token成本对比分析工具
最近在团队里做AI项目时,经常遇到一个头疼的问题:API调用成本太高。特别是当需要频繁测试和迭代时,代币消耗就像流水一样。直到发现了openclaw-zero-token技术,才意识到原来有这么多优化空间。为了更直观地对比传统调用和zero-tok…...
新手福音:零基础在快马平台创建你的第一个口播智能体
今天想和大家分享一个特别适合编程新手的实战项目——在InsCode(快马)平台上创建一个旗博士口播智能体。这个项目不需要任何后端知识,用最基础的HTML和JavaScript就能实现,而且能让你直观感受到AI应用的开发流程。 项目整体思路 这个口播智能体的核心功能…...
Windows 11终极优化指南:用Win11Debloat免费提升系统性能51%
Windows 11终极优化指南:用Win11Debloat免费提升系统性能51% 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter …...
如何高效加速GitHub下载:Fast-GitHub插件的完整指南
如何高效加速GitHub下载:Fast-GitHub插件的完整指南 【免费下载链接】Fast-GitHub 国内Github下载很慢,用上了这个插件后,下载速度嗖嗖嗖的~! 项目地址: https://gitcode.com/gh_mirrors/fa/Fast-GitHub 你是否经常因为Git…...
