当前位置: 首页 > article >正文

QueryWrapper常用案例

记录于 2023.09.18 个人博客现转录CSDNQueryWrapper MyBatis-Plus 提供的「SQL 条件自动拼接工具」不用手写 SQL 语句用 Java 链式代码自动帮你拼出 where、order by、like、in、between 等查询条件。1.多条数据查询import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import org.apache.commons.lang3.StringUtils; import org.springframework.stereotype.Service; import java.util.Map; Service(xxService) public class XxServiceImpl extends ServiceImplXxDao, IndexEntity implements XxService { Override public ListIndexEntity getList(MapString, Object params) { LambdaQueryWrapperIndexEntity qw new LambdaQueryWrapper(); // 日期 ? qw.apply(StringUtils.isNotBlank((String) params.get(statisDate)), to_date(STATIS_DATE, yyyy-mm-dd) {0}, params.get(statisDate)); // 类型 ? qw.eq(params.containsKey(Type) params.get(Type) ! null, IndexEntity::getType, params.get(Type)); // 时间范围防注入 qw.apply(params.containsKey(insertTimeStart) params.containsKey(insertTimeEnd), INSERT_TIME BETWEEN to_date({0}, yyyy-mm-dd) AND to_date({1}, yyyy-mm-dd), params.get(insertTimeStart), params.get(insertTimeEnd)); // 模糊查询 qw.like(params.containsKey(province) params.get(province) ! null, IndexEntity::getProvince, params.get(province)); // 非空 排序 qw.isNotNull(IndexEntity::getIndexId) .orderByAsc(IndexEntity::getCreateTime); return list(qw); } }原代码特点混合使用 普通 QueryWrapper lambda ()直接用 字符串拼接 SQL日期、between条件多等于、日期、范围、模糊、非空、排序从 Map 取参数判空方式不统一优点能实现功能逻辑清晰能看懂缺点非常关键严重 SQL 注入风险直接拼参数混用普通字段 Lambda极不规范容易空指针params.get () 没判空代码丑、难维护Oracle 函数写死移植性差适合场景临时需求、快速开发、内部小系统2.select指定字段Override public PageUtils queryPage(MapString, Object params) { LambdaQueryWrapperCUserEntity qw new LambdaQueryWrapper(); // 只查询需要的字段实体类引用不会写错 qw.select( CUserEntity::getId, CUserEntity::getXxx, CUserEntity::getSs, CUserEntity::getStatisDate ); // 日期范围安全写法 qw.apply(StringUtils.isNotBlank((String) params.get(statisDateStart)), STATIS_DATE BETWEEN to_date({0}, yyyy-MM-dd hh24:mi:ss) AND to_date({1}, yyyy-MM-dd hh24:mi:ss), params.get(statisDateStart), params.get(statisDateEnd)); // 排序 qw.orderByAsc(CUserEntity::getStatisDate); // 分页 IPageCUserEntity page this.page(new QueryCUserEntity().getPage(params), qw); return new PageUtils(page); }原代码特点使用 .select() 自定义查询字段含别名、日期格式化用 apply 拼接日期范围分页查询优点只查需要字段性能好分页正常工作缺点手写字段字符串容易写错别名混乱id as 、xxx as ssSQL 注入风险日期格式化硬编码适合场景需要自定义返回字段、报表查询3.为读xml文件的sql添加ipage页面Dao 接口Mapper public interface XxDao extends BaseMapperXxEntity { IPageMapString, Object relationInfoPage(IPage? page, Param(id) String id); }ServiceOverride public IPageMapString, Object relationInfoPage(MapString, Object params) { IPageMapString, Object page new QueryMapString, Object().getPage(params); String id params.get(xId) null ? : params.get(xId).toString(); return xxDao.relationInfoPage(page, id); }XMLOracle 驼峰映射resultMap typecom.z.xxEntity idxxMap result propertyxId columnDIX_ID/ result propertysceneName columnSCENE_NAME/ result propertysceneState columnSCENE_STATE/ /resultMap select idrelationInfoPage resultMapxxMap select * from xxx where DIX_ID #{id} order by CREATE_TIME asc /select原代码特点不使用 QueryWrapper自己写 XML SQL给 自定义 XML 方法加分页用 resultMap 解决 Oracle 大写字段转驼峰优点最灵活复杂 SQL 只能这么写性能可控联表、分组、子查询resultMap 解决 Oracle 大小写问题 非常正确分页能正常工作缺点代码量多要写 XML不够爽不能用 Lambda字段硬编码适合场景复杂多表查询统计查询集团 / 企业规范要求4. LambdaQueryWrapper 分页 / 列表最简洁版带/不带分页LambdaQueryWrapperResouseEntity lambdaQueryWrapper new LambdaQueryWrapper(); lambdaQueryWrapper.eq(ResouseEntity::getTaskId, taskId); IPageResouseEntity iPage ponCutoverOnuInfoService.page(new QueryResouseEntity().getPage(params), lambdaQueryWrapper); // ListResouseEntity list ponCutoverOnuInfoService.list(lambdaQueryWrapper); log.info(查询业务设计结束 JSON.toJSONString(iPage)); return R.ok().put(data, iPage);原代码特点纯 Lambda不写字段名简洁、干净分页 / 列表二选一优点最规范、最安全不易写错字段代码最简洁无 SQL 注入企业最推荐写法缺点复杂函数Oracle 的 to_date无法直接用必须搭配 apply适合场景90% 的日常单表查询增删改查

相关文章:

QueryWrapper常用案例

记录于 2023.09.18 个人博客,现转录CSDNQueryWrapper MyBatis-Plus 提供的「SQL 条件自动拼接工具」 不用手写 SQL 语句,用 Java 链式代码,自动帮你拼出 where、order by、like、in、between 等查询条件。 1.多条数据查询 import com.baomid…...

跨语言数据处理的高效解决方案:json-translator全方位指南

跨语言数据处理的高效解决方案:json-translator全方位指南 【免费下载链接】json-translator jsontt 💡 - AI JSON Translator with GPT / Gemma / Mixtral / llama other FREE translation modules to translate your json/yaml files into other lang…...

文墨共鸣效果展示集:多组文本对比,看朱砂印如何演绎语义远近

文墨共鸣效果展示集:多组文本对比,看朱砂印如何演绎语义远近 当冰冷的算法代码遇上温润的东方水墨,会碰撞出怎样的火花?今天,我们不谈复杂的部署,也不讲深奥的原理,只做一件事:静静…...

OpenClaw安全指南:Qwen3.5-9B模型下的权限管控实践

OpenClaw安全指南:Qwen3.5-9B模型下的权限管控实践 1. 为什么需要关注OpenClaw的安全管控? 去年冬天的一个深夜,我被一阵急促的硬盘读写声惊醒。打开终端查看,发现是OpenClaw正在疯狂扫描我的整个Documents文件夹——原来是我白…...

告别万用表!用ESP32和PlatformIO搭建一个简易电压监测器(实时串口绘图)

用ESP32打造实时电压监测系统:从硬件搭建到数据可视化 在物联网和智能硬件开发中,电压监测是一个基础但至关重要的功能。无论是电池电量监控、太阳能系统管理,还是简单的电子实验,实时了解电压变化都能帮助我们更好地理解系统状态…...

终极指南:如何将unplugin-icons与Rspack构建工具深度集成

终极指南:如何将unplugin-icons与Rspack构建工具深度集成 【免费下载链接】unplugin-icons 🤹 Access thousands of icons as components on-demand universally. 项目地址: https://gitcode.com/gh_mirrors/un/unplugin-icons 在前端开发领域&am…...

[技术突破] 解决营销行业3大痛点:基于control_v1p_sd15_qrcode_monster的创新方案

[技术突破] 解决营销行业3大痛点:基于control_v1p_sd15_qrcode_monster的创新方案 【免费下载链接】control_v1p_sd15_qrcode_monster 项目地址: https://ai.gitcode.com/hf_mirrors/monster-labs/control_v1p_sd15_qrcode_monster 一、痛点剖析&#xff1a…...

ImportExcel版本更新:7.8.10新特性解析和改进点详解

ImportExcel版本更新:7.8.10新特性解析和改进点详解 【免费下载链接】ImportExcel PowerShell module to import/export Excel spreadsheets, without Excel 项目地址: https://gitcode.com/gh_mirrors/im/ImportExcel ImportExcel是一款强大的PowerShell模块…...

HiFloat8:高性能训练之路

Float8单数据格式FP8/HiF8训练算法介绍Float8混合精度训练策略随着预训练模型(尤其是基于Transformer架构的大语言模型)参数规模突破千亿级,训练过程面临愈发严重的算力和内存瓶颈,成本极高。在此背景下,8位浮点逐渐成…...

HiFloat8高效训推技术报告(2):HiFloat8高效低比特推理

1. 低比特推理背景知识深度学习模型在训练和推理阶段通常使用 FP32 (32位浮点数) 或 BF16/FP16 (16位浮点数) 格式。然而,随着模型规模的不断增大(尤其是大型语言模型 LLM),对计算效率、显存占用和能耗的要求也越来越高。低比特推…...

集合通信处理器(CCU)技术解读文档

摘要在大规模分布式训练和推理业务中,集合通信的性能是影响整体系统性能的关键瓶颈之一。传统集合通信方式依赖AI CPU、AI Vector等计算单元通过软件协议栈构造通信任务描述符,驱动硬件执行通信任务。然而,这种执行方式不仅需要占用计算核资源…...

Pronto性能优化技巧:如何加速大规模项目的代码审查

Pronto性能优化技巧:如何加速大规模项目的代码审查 【免费下载链接】pronto Quick automated code review of your changes 项目地址: https://gitcode.com/gh_mirrors/pr/pronto Pronto是一款高效的自动化代码审查工具,专为快速检查代码变更而设…...

戴森球计划蓝图库:从模块化部署到系统思维的生产革命

戴森球计划蓝图库:从模块化部署到系统思维的生产革命 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints 在戴森球计划的浩瀚宇宙中,高效的工厂设计是星…...

为什么头部自动驾驶团队已在预研C++27反射?——静态反射在嵌入式ABI稳定、安全认证代码生成中的不可替代性揭秘

第一章:C27静态反射的演进脉络与战略定位C27静态反射并非凭空而生,而是ISO C标准化进程中长达十年深度探索的结晶。它继承并重构了C17的std::is_same、C20的std::source_location与反射TS(P0194R8)的语义骨架,同时彻底…...

黑豹X2(Panther-x2)刷机实战:Armbian系统部署与Jellyfin硬件加速配置

1. 黑豹X2设备与Armbian系统简介 黑豹X2(Panther-x2)是一款基于Rockchip RK3566处理器的ARM架构迷你电脑,标配4GB内存和32GB eMMC存储,配备千兆网口、TF卡扩展槽以及无线蓝牙模块。这款设备最大的亮点在于其内置的NPU(…...

如何开发GJSON自定义修饰符:扩展你的JSON处理能力

如何开发GJSON自定义修饰符:扩展你的JSON处理能力 【免费下载链接】gjson Get JSON values quickly - JSON parser for Go 项目地址: https://gitcode.com/gh_mirrors/gj/gjson GJSON是Go语言中一款高效的JSON解析工具,它允许开发者快速从JSON数据…...

网易云音乐无损解析工具:从音质痛点到音乐收藏全方案

网易云音乐无损解析工具:从音质痛点到音乐收藏全方案 【免费下载链接】Netease_url 网易云无损解析 项目地址: https://gitcode.com/gh_mirrors/ne/Netease_url 你是否曾在制作音乐混剪时,因找不到高解析度音频素材而妥协?是否为整理多…...

为什么你的背包背带总在“溜肩”?

Q:为什么有些背包的背带总是往下滑,调整多次也没用? A:这通常是背带“S形曲线”设计不合理导致的。专业背包的肩带并非简单的直线,而是根据人体锁骨和肩胛骨的自然弧度,采用8-12度的复合曲面设计。迪先实验…...

5步掌握B站高清视频下载:开源工具bilibili-downloader完整指南

5步掌握B站高清视频下载:开源工具bilibili-downloader完整指南 【免费下载链接】bilibili-downloader B站视频下载,支持下载大会员清晰度4K,持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 还在为无法…...

告别排版地狱:PaperXie AI,10 分钟让你的毕业论文合规 “零返工”

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/AIPPThttps://www.paperxie.cn/format/typesettinghttps://www.paperxie.cn/format/typesetting 引言:被格式细节毁掉的毕业努力 当你熬了无数个夜晚,反复打磨论文的每一个论点&…...

从零到上线仅需4步,Mojo调用Python生态的隐藏API全解密,内部技术白皮书首次公开

第一章:从零到上线仅需4步,Mojo调用Python生态的隐藏API全解密,内部技术白皮书首次公开Mojo 作为新一代系统级编程语言,原生支持无缝调用 Python 生态——但其关键能力并非来自 import 语句,而是通过未公开的 python 装…...

如何通过WeChatMsg实现微信聊天记录的永久保存与智能分析?

如何通过WeChatMsg实现微信聊天记录的永久保存与智能分析? 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/W…...

解密AI艺术二维码:5步掌握control_v1p_sd15_qrcode_monster实战进阶

解密AI艺术二维码:5步掌握control_v1p_sd15_qrcode_monster实战进阶 【免费下载链接】control_v1p_sd15_qrcode_monster 项目地址: https://ai.gitcode.com/hf_mirrors/monster-labs/control_v1p_sd15_qrcode_monster 你是否曾为传统二维码的单调外观感到遗…...

Whisper JAX终极错误排查手册:10个常见问题与快速解决方案 ⚡️

Whisper JAX终极错误排查手册:10个常见问题与快速解决方案 ⚡️ 【免费下载链接】whisper-jax JAX implementation of OpenAIs Whisper model for up to 70x speed-up on TPU. 项目地址: https://gitcode.com/gh_mirrors/wh/whisper-jax Whisper JAX是基于JA…...

Windows系统优化神器Winhance:让电脑飞起来的终极指南 [特殊字符]

Windows系统优化神器Winhance:让电脑飞起来的终极指南 🚀 【免费下载链接】Winhance-zh_CN A Chinese version of Winhance. C# application designed to optimize and customize your Windows experience. 项目地址: https://gitcode.com/gh_mirrors/…...

Mirage: The Illusion of Visual Understanding

Lab4AI大模型实验室是面向AI开发者、科研党与学习者打造的一站式AI实践平台,深度绑定高性能弹性算力,支持模型复现、训练、推理全流程,以按需计费、低价高效破解高端算力紧缺与成本高昂难题;同步Arxiv前沿论文并提供翻译、导读、分…...

终极指南:如何诊断和优化SeetaFaceEngine的运行速度瓶颈

终极指南:如何诊断和优化SeetaFaceEngine的运行速度瓶颈 【免费下载链接】SeetaFaceEngine 项目地址: https://gitcode.com/gh_mirrors/se/SeetaFaceEngine SeetaFaceEngine是一个高性能的开源人脸识别引擎,包含人脸检测、人脸对齐和人脸识别三大…...

MEMC插帧技术与屏幕分辨率术语解析:从VGA到8K的演进与应用

1. MEMC插帧技术:让画面流畅的秘密武器 第一次在朋友家看体育比赛直播时,我被那种丝滑般的画面震撼到了——足球飞行的轨迹完全没有拖影,运动员的每个动作都清晰可见。后来才知道,这背后是MEMC动态插帧技术在发挥作用。这项技术如…...

告别卡顿!用华为云ECS搭建高性能eNSP Pro服务器,支持大规模组网实验

华为云ECS深度优化指南:解锁eNSP Pro大规模组网实验的终极性能 当你在本地PC上运行eNSP Pro进行网络实验时,是否遇到过这样的困境:模拟5台设备就开始卡顿,复杂拓扑直接崩溃,或者保存配置时进度条像蜗牛爬行&#xff1f…...

TCN实战:用Python和Keras搭建时序分类模型(附MNIST代码)

TCN实战:用Python和Keras搭建时序分类模型(附MNIST代码) 时序数据分类一直是机器学习领域的核心挑战之一。传统RNN架构虽然广泛应用,但其训练复杂度高、并行性差的缺陷日益凸显。2018年提出的时域卷积网络(TCN&#xf…...