使用 MyBatisPlus 的注解方式进行 SQL 查询,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。
MyBatis-Plus 是一个基于 MyBatis 的增强工具,它提供了一套方便的注解方式来进行 SQL 查询。其中,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。
官网:条件构造器 | MyBatis-Plus
1、使用 Wrapper 自定义SQL注意事项
需要
mybatis-plus版本 >=3.0.7
2、直接通过一个简单的示例进行讲解:
假设我们有一个名为"Order"的表,包含"orderId"和"amount"两列:
import lombok.Data;
import java.math.BigDecimal;
import java.time.LocalDateTime;@Data
public class Order {private Long orderId;private Long userId;private BigDecimal amount;private LocalDateTime createTime;
}
现在,我们要查询某个用户在指定时间范围内的订单金额总和。可以按照以下方式编写代码:
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.reflection.Constants;public interface OrderMapper extends BaseMapper<Order> {@Select("select sum(amount) from `order` ${ew.customSqlSegment}")BigDecimal queryTotalAmountByUserAndDate(@Param(Constants.WRAPPER) LambdaQueryWrapper<Order> wrapper);
}
在上述代码中,我们定义了一个接口OrderMapper,继承自BaseMapper<Order>,并添加了一个方法queryTotalAmountByUserAndDate用于查询订单金额总和。LambdaQueryWrapper<Order>用于构建查询条件。
接下来,在你的业务逻辑代码中,可以按照以下方式使用该方法:
import java.math.BigDecimal;
import java.time.LocalDateTime;// ...private BigDecimal queryTotalAmountByUserAndDate(Long userId, LocalDateTime begin, LocalDateTime end) {LambdaQueryWrapper<Order> wrapper = new LambdaQueryWrapper<Order>().eq(Order::getUserId, userId).between(Order::getCreateTime, begin, end);BigDecimal totalAmount = orderMapper.queryTotalAmountByUserAndDate(wrapper);return totalAmount == null ? BigDecimal.ZERO : totalAmount;
}
在上述代码中,我们创建了一个LambdaQueryWrapper<Order>对象,并使用eq方法和between方法分别指定了用户ID和时间范围的条件。
然后,我们调用queryTotalAmountByUserAndDate方法,并传入该wrapper对象进行查询。最后,根据查询结果判断并返回订单金额总和。
3、具体分析二者是如何结合使用的
(1)当使用SQL和Wrapper结合进行查询时,SQL用于编写具体的SQL语句,而Wrapper用于构建查询条件。
(2)SQL语句中的${ew.customSqlSegment}会被Wrapper对象中的条件替换,从而形成最终的SQL查询语句。Wrapper对象中的条件会根据具体的方法调用来生成相应的SQL片段,并替换${ew.customSqlSegment}。
在示例中:
我们使用了
LambdaQueryWrapper作为Wrapper对象,它提供了一系列方法来构建查询条件,如eq、between等。同时,我们在SQL语句中使用了
sum(amount)来求和,这个部分是纯粹的SQL语法。最后,通过调用
queryTotalAmountByUserAndDate方法,我们将Wrapper对象传递给Mapper接口的查询方法,并使用${ew.customSqlSegment}将Wrapper中的条件注入到SQL语句中。执行查询后,得到的结果会返回给调用方。
(3)综上所述,SQL和Wrapper的结合使用,可以通过Wrapper构建查询条件,然后将条件注入到SQL语句中,从而实现灵活的查询操作。
4、这样使用的原因
因为,MyBatis-Plus并没有直接提供对于SUM求和的方法。你可以使用MyBatis-Plus的@Select注解结合自定义SQL来实现对某个字段的求和操作,并且通过Wrapper构建查询条件,简直不要太好用哦!!!
相关文章:
使用 MyBatisPlus 的注解方式进行 SQL 查询,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。
MyBatis-Plus 是一个基于 MyBatis 的增强工具,它提供了一套方便的注解方式来进行 SQL 查询。其中,它结合了条件构造器(Wrapper)和自定义 SQL 片段来构建查询语句。 官网:条件构造器 | MyBatis-Plus 1、使用 Wrapper …...
Python中统计单词出现的次数,包含(PySpark方法)
思路: 定义一个函数,使用open函数,将文本内容打开。 定义一个空字典和空列表,进行循环及条件判断操作def count_word(file_path):dict_data {} #定义一个空字典f open(file_path,"r",encoding"UTF-8")lis…...
探讨基于IEC61499 的分布式 ISA Batch 控制系统
ISA SP88 是批次过程控制的标准,对应的IEC标准是IEC 61512。该标准中一个重要的部分是配方管理(Recipe Management)。 所谓配方,是根据批量产品的要求,材料设定加工工艺,加工流程和参数。类似于传统制造业的…...
图论16(Leetcode863.二叉树中所有距离为K的结点)
答案: /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode(int x) { val x; }* }*/ class Solution {public List<Integer> distanceK(TreeNode root, TreeNode tar…...
【小沐学C++】C++ MFC中嵌入64位ActiveX控件(VS2017)
文章目录 1、简介1.1 MFC1.2 ActiveX 2、VS2017添加ActiveX控件结语 1、简介 1.1 MFC Microsoft 基础类 (MFC) 库针对大部分 Win32 和 COM API 提供面向对象的包装器。 虽然此包装器可用于创建极为简单的桌面应用程序,但当你需要开发具有多个控件的更复杂的用户界…...
Linux常用命令—find命令大全
文章目录 一、find命令常用功能1、find命令的基本信息如下。2、按照文件名搜索3、按照文件大小搜索4、按照修改时间搜索5、按照权限搜索举例:6、按照所有者和所属组搜索7、按照文件类型搜索8、逻辑运算符 一、find命令常用功能 1、find命令的基本信息如下。 命令名…...
form组件的封装(element ui ) 简单版本
当你使用Vue.js构建Web应用时,封装可复用组件是提高开发效率和代码可维护性的关键之一。在这篇文章中,我们将探讨如何使用Vue.js来创建一个通用的表单组件,以及如何将它封装成一个可配置的组件。 实现思路 拿下表单模板一个个的改造&#x…...
树形DP杂题
引 对老师布置的题目稍微记录一下吧 也算对树形 D P DP DP 的巩固 T1 Ostap and Tree 题目传送门 由于有 距离 k 距离k 距离k 的限制,设计二维 d p dp dp 设计状态: f i , j : i 的子树内,离 i 最近的染色点与 i 距离为 j 且若 j <…...
Webpack使用plugin插件自动在打包目录生成html文件
我们使用html-webpack-plugin插件可以自动在打包代码目录生成html文件 使用步骤: 一、安装依赖 在控制台中输入如下代码: npm i -D html-webpack-plugin 二、在webpack.config.js中配置插件 const HTMLPlugin require("html-webpack-plugin&q…...
图像处理与计算机视觉--第一章-计算机视觉简介-10问
第一章-计算机视觉简介-10问 1.CV与AI的关系是什么? CV(Computer Vision)是Al的子领域,它致力于使计算机能够理解和解释图像和数据,CV借助AI技术,比如深度学习/机器学习,实现目标识别,分析和处理任务。AI提供了CV所需要的算法…...
LeetCode 80. 删除有序数组中的重复项 II
文章目录 一、题目二、Java 题解 一、题目 给你一个有序数组 nums,请你 原地 删除重复出现的元素,使得出现次数超过两次的元素只出现两次 ,返回删除后数组的新长度。 不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用…...
【前端面试题】浏览器面试题
文章目录 前言一、浏览器面试问题1.cookie sessionStorage localStorage 区别2.如何写一个会过期的localStorage,说说想法2.如何定时删除localstorage数据2.localStorage 能跨域吗2.memory cache 如何开启2.localstorage的限制2.浏览器输入URL发生了什么2.浏览器如何…...
PHP 生成 PDF文件
参考官网 Example 009 : Image() TCPDF laravel 可以使用 composer 安装 tecnickcom/tcpdf 进行使用 //require_once("../app/Extend/tcpdf/tcpdf.php"); $pdf new TCPDF();// 设置文档信息$pdf->SetCreator(懒人开发网);$pdf->SetAuthor(懒人开发网);$…...
讲讲项目里的仪表盘编辑器(一)
需求 要做一个仪表盘系统,要求有: ① 设计功能(包括布局、大小、排列) ② 预览功能 ③ 运行功能 布局选择 做编辑器,肯定要先选择布局。 前端有几种常用布局。 静态布局 也叫文档布局。默认的网页形式…...
解决方案 | 如何构建市政综合管廊安全运行监测系统?
如何构建市政综合管廊安全运行监测系统?WITBEE万宾城市生命线智能监测仪器,5年免维护设计,集成10多项结构与气体健康监测指标,毫秒级快速响应,时刻感知综合管廊运行态势...
JCEF中js与java交互、js与java相互调用
jcef中js与java相互调用,java与js相互调用,chrome与java相互调用,java与chrome相互调用、jcef与java相互调用 前提:https://blog.csdn.net/weixin_44480167/article/details/133170970(java内嵌浏览器CEF-JAVA、jcef、…...
9.20 校招 实习 内推 面经
绿泡*泡: neituijunsir 交流裙 ,内推/实习/校招汇总表格 1、校招丨智行者2024年校园招聘正式启动啦 校招丨智行者2024年校园招聘正式启动啦 2、校招 | 乐动机器人2024校园招聘 校招 | 乐动机器人2024校园招聘 3、校招丨小天才2024届秋季校园招聘 …...
基于JAVA+SpringBoot+Vue+协同过滤算法+爬虫的前后端分离的租房系统
✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取项目下载方式🍅 一、项目背景介绍: 随着城市化进程的加快…...
【Android Framework系列】第16章 存储访问框架 (SAF)
1 概述 Android 4.4(API 级别 19)引入了存储访问框架 (Storage Access Framework)。SAF让用户能够在其所有首选文档存储提供程序中方便地浏览并打开文档、图像以及其他文件。 用户可以通过易用的标准 UI,以统一方式在所有应用和提供程序中浏…...
Antdesign 4中让分页组件居中显示的方法
在Ant Design 4中分页组件默认是最右边显示的,而这个没有设置位置的属性的 解决办法: 在pagination的属性中增加: style: {textAlign: "center"} 在Ant Design 5中可以让pagination使用align: center来实现分页组件居中...
英雄联盟智能助手:3分钟上手,让你的游戏体验提升300%
英雄联盟智能助手:3分钟上手,让你的游戏体验提升300% 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 还在为英雄选择犹…...
三步解锁WeMod Pro高级功能:Wand-Enhancer终极免费方案
三步解锁WeMod Pro高级功能:Wand-Enhancer终极免费方案 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 想要完全免费享受WeMod Pro的所有高级…...
基于Whisper与VS Code的语音编程氛围系统构建指南
1. 项目概述:当语音输入遇上沉浸式编程最近在GitHub上看到一个挺有意思的项目,叫voice-typing-vibe-coding。光看名字,你可能会觉得这又是一个简单的语音转代码工具,但实际体验下来,我发现它的野心远不止于此。它试图解…...
2026年写作类国际竞赛都有哪些?留学背景提升首选赛事全解析
AI 问答摘要块 Q:2026 年写作类国际竞赛都有哪些? A:2026 年值得参加的高含金量国际写作竞赛主要包括:1. Cosmopolitan Writing Award(CWA)(全球首创 AI 评审机制,全年龄段覆盖,留学背景提升首选…...
Sora 2 × YouTube双平台协同工作流:自动生成多尺寸横竖版+智能章节标记+CC字幕同步(仅需1次Prompt)
更多请点击: https://intelliparadigm.com 第一章:Sora 2 YouTube双平台协同工作流全景概览 Sora 2 作为新一代多模态生成引擎,已原生支持高保真视频结构化输出与语义时间轴标注;YouTube 则通过 Creator Studio API 和 Data API…...
基于RAG的智能文档问答系统:从原理到DocsGPT实战部署
1. 项目概述:当文档库遇上大语言模型如果你和我一样,经常需要和一堆技术文档、API手册或者内部知识库打交道,那你肯定体会过那种“大海捞针”的痛苦。明明知道答案就在某个PDF、某个网页或者某个Markdown文件里,但你就是找不到。传…...
MATLAB imagesc保姆级教程:从单一热图到多图排版,附完整代码
MATLAB imagesc全攻略:从热图绘制到高级排版实战 在数据科学和工程领域,可视化是理解复杂矩阵数据不可或缺的一环。MATLAB作为技术计算领域的标杆工具,提供了imagesc这一强大的矩阵可视化函数,能够将抽象的数字矩阵转化为直观的热…...
串口数据监控软件开发总结
1.飞控发送太快,串口传输太慢,导致大量数据包粘包,残包,丢失 本次针对串口数据解析,就使用了一个1k的buf作为缓冲,用递归函数解包,打包。线程只做读取,单独开子线程处理数据。 2套半…...
《2026 年生成电商主图最好的 5 个软件,实测后我只留了这几款》
做电商 5 年,从淘宝做到亚马逊,我用过的主图设计工具不下 20 款。2026 年 AI 工具爆发后,很多老软件其实已经被淘汰了。这篇把我目前还在用的 5 款整理出来,都是真金白银测过的,不是广告。先说结论:如果你只看一句话——想一键出主图详情页全套:选潮际好麦只做白底主图:选佐糖要…...
高颜值、免费又好用的Linux命令速查神器:TUX星球,强烈推荐给大家!!
Linux 命令总是记不住?比死背更重要的是先学会“怎么查” 很多人刚开始接触 Linux 时,都会遇到一个很真实的问题:命令太多,参数太多,今天刚查过的 tar、grep、find,过两天又忘了;线上排查问题时…...
