JavaWeb学习--MyBatis-Plus整合SpringBoot的ServiceImpl方法(增加,修改与删除部分)
接下来是常用的增加,修改以及删除部分
首先是增加部分,增加一个新的数据
@Testpublic void testInsert() {// 添加一个新用户记录Student s = new Student();s.setName("NewStudent");s.setAge(25);boolean saved = studentService.save(s);//可以根据saved来进行后续处理,添加成功则saved=true,反之为false}
然后是批量添加数据:
@Testpublic void testSaveBatch() {// 批量插入多个数据ArrayList<Student> students = new ArrayList<>();for (int i = 0; i < 5; i++) {Student student = new Student();student.setName("Student" + i);student.setAge(20 + i);students.add(student);}boolean saved = studentService.saveBatch(students);//可以根据saved来进行后续处理,添加成功则saved=true,反之为false}
通常情况下,以上2种的添加方式可以满足大部分的需求,然后是修改部分:
@Testpublic void testUpdateById() {// 根据ID更新用户记录Student s = new Student();s.setId(1L);s.setAge(18);boolean updated = studentService.updateById(s);//后续可以根据updated 进行一些别的处理,true为修改成功,false为修改失败}
运行结果如下:
然后是自定义条件修改数据
@Testpublic void testUpdate() {// 自定义条件修改数据QueryWrapper<Student> queryWrapper = new QueryWrapper<>();//使用Wrapper记录条件queryWrapper.like("name", "折");//模糊查询queryWrapper.eq("sex", "女");Student s = new Student();s.setAge(17);boolean updated = studentService.update(s, queryWrapper);}
运行结果如下:

然后是根据id批量修改:
@Testpublic void testUpdateBatchById() {// 根据id批量修改用户记录List<Student> ss = new ArrayList<>();for (int i = 23; i <= 27; i++) {Student s = new Student();s.setId((long) i);s.setName("NewStudent" + i);s.setAge(30 + i);ss.add(s);}boolean updated = studentService.updateBatchById(ss);}
运行结果如下:
然后是修改或者添加数据
@Testpublic void testSaveOrUpdate() {// 更新数据,如果没有这个数据,则改为添加Student s = new Student();s.setId(12L);s.setAge(40);boolean savedOrUpdate = studentService.saveOrUpdate(s);}
运行结果如下:
没有数据时
有数据时:

在上面的基础上,增加判断条件部分:
@Testpublic void testSaveOrUpdateWithWrapper() {// 更新或插入用户记录Student s = new Student();s.setId(11L);s.setName("澪");s.setAge(55);QueryWrapper<Student> updateWrapper = new QueryWrapper<>();//用于修改用户时判断updateWrapper.eq("name", "澪");boolean savedOrUpdate = studentService.saveOrUpdate(s, updateWrapper);}
没有数据时:
有数据时:

最后是删除部分
首先是根据id删除:
@Testpublic void testRemoveById() {// 根据ID删除一个用户记录boolean removed = studentService.removeById(12L);}
运行代码如下:
由于案例开启了逻辑删除,所以这里采用的是逻辑删除的方式,如果没有开启逻辑删除,则会在数据库中删除这个数据
然后是使用实体类的id删除
@Testpublic void testRemoveByIdWithEntity() {// 根据实体对象删除一个用户记录Student s = new Student();s.setId(13L);s.setAge(11);boolean removed = studentService.removeById(s);assertTrue(removed);}
结果如下
可以看到,这个只能根据实体类的id删除,而不能根据其内部的其他数据来删除,而使用map和Wrapper可以实现根据条件删除:
首先是map:
@Testpublic void testRemoveByMap() {// 根据条件删除用户记录Map<String, Object> Map = new HashMap<>();Map.put("age", "111");boolean removed = studentService.removeByMap(Map);}
运行结果如下:

接下来是Wrapper
@Testpublic void testRemoveByWrapper() {// 根据条件删除用户记录QueryWrapper<Student> queryWrapper = new QueryWrapper<>();queryWrapper.eq("age", "22");queryWrapper.like("name", "1");//模糊查询boolean removed = studentService.remove(queryWrapper);}
结果如下:
最后是批量删除:
@Testpublic void testRemoveByIds() {// 根据ID列表批量删除用户记录List<Long> ids = Arrays.asList(21L, 20L);boolean removed = studentService.removeByIds(ids);}
运行结果如下:

相关文章:
JavaWeb学习--MyBatis-Plus整合SpringBoot的ServiceImpl方法(增加,修改与删除部分)
接下来是常用的增加,修改以及删除部分 首先是增加部分,增加一个新的数据 Testpublic void testInsert() {// 添加一个新用户记录Student s new Student();s.setName("NewStudent");s.setAge(25);boolean saved studentService.save(s);//可以…...
AiCube 试用 - 创建流水灯工程
AiCube 试用 - 创建流水灯工程 本文介绍了 Aiapp-ISP 仿真调试平台软件的 AiCube 工具,实现流水灯工程的快速创建的主要流程。 下载运行 下载 最新版 AIapp-ISP 软件; 解压并打开该软件,右侧操作界面选择并进入 Keil 仿真设置 标签项&…...
【Kafka基础】Kafka工作原理解析
Apache Kafka作为当今最流行的分布式消息系统,以其高吞吐、低延迟和高可靠性的特点,成为大数据领域不可或缺的基础设施。本文将深入剖析Kafka的核心架构和工作原理,帮助开发者全面理解这一强大的消息引擎。 1 Kafka架构解析 Kafka采用分布式、…...
GISBox:核心功能免费的一站式三维GIS处理平台
大家好,今天为大家介绍的软件是GISBox:一款核心功能免费的一站式三维GIS处理平台,主要是适用于数字孪生。下面,我们将从软件的主要功能、支持的系统、软件官网等方面对其进行简单的介绍。 软件官网:http://www.gisbox.…...
【论文笔记】DeepSeek-R1 技术报告
最强开源LLM,性能和效果都很棒;在数学、代码这种有标准正确答案的场景,表现尤为突出;一些其他场景的效果,可能不如DeepSeek-V3和Qwen。 Deepseek-R1没有使用传统的有监督微调sft方法来优化模型,而使用了大规…...
基于javaweb的SSM羽毛球会员俱乐部系统场馆课程运动设计与实现(源码+文档+部署讲解)
技术范围:SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…...
[dp4_路径问题] 下降路径最小和 | 最小路径和 | 地下城游戏
目录 1.下降路径最小和 题解 2.最小路径和 题解 3.地下城游戏 题解 做算法题的时候,谨记图画得越详细越好,思路想的越清晰越好,然后再用代码实现一下就好啦 1.下降路径最小和 链接:931. 下降路径最小和 给你一个 n x n 的…...
EasyExcel 数据字典转换器实战:注解驱动设计
一、场景痛点与解决方案 1. 问题背景 在 Excel 导入导出场景中,开发者常面临以下问题: 数据可读性差:数据库存储的字典值(如 1、true)直接导出时难以理解双向转换复杂:导入时需将用户输入的标签反向解析…...
【蓝桥杯】算法笔记2
这篇文章主要记录动态规划方面的学习。 动态规划的核心思想: 把大问题分解成小问题,记住小问题的解,避免重复计算。 动态规划(DP)的三大特点: ①最优子结构:大问题的最优解可以由小问题的最优解推导出来 ②重叠子问题:在求解过程中会反复遇到相同的小问题 ③无后效…...
解决STM32CubeMX中文注释乱码
本人采用【修改系统环境变量】的方法 1. 使用快捷键 win X,打开【系统R】,点击【高级系统设置】 2. 点击【环境变量】 3. 点击【新建】 4.按图中输入【JAVA_TOOL_OPTIONS】和【-Dfile.encodingUTF-8】,新建环境变量后重启CubeMX即可。 解释…...
AI产品的上层建筑:提示词工程、RAG与Agent
上节课我们拆解了 AI 产品的基础设施建设,这节课我们聊聊上层建筑。这部分是产品经理日常工作的重头戏,包含提示词、RAG 和 Agent 构建。 用 AI 客服产品举例,这三者的作用是这样的: 提示词能让客服很有礼貌。比如它会说&#x…...
基于自定义注解+反射+AOP+Redis的通用开关设计:在投行交易与风控系统的落地实践
一句话总结🤣 一个注解让业务逻辑自动切换,Redis当起了隐形操盘手 业务痛点和需求场景 交易系统需支持毫秒级动态切换报价策略,如切换到备用流动性通道风控模型需支持灰度发布(10%流量测试新权重算法)和紧急熔断&am…...
RK3588使用笔记:ubuntu/麒麟系统功能测试程序
一、前言 本编文章记录在使用嵌入式系统中的一些功能测试demo程序,大部分都是AI写的,哈哈哈,确实很有帮助,但是得根据自身设备实际情况和知道如何问AI,才能得出你想要的结果,本文就记录一些ubuntu/麒麟系统…...
Unity中优化绘制调用整理
DrawCall 指的是 CPU 向 GPU 发送渲染指令的过程,在 Unity 中,每次渲染一个网格时,CPU 都需要向 GPU 发送一系列的渲染指令,这个过程被称为一次绘制调用(Draw Call)。 1.GPU实例化 使用: 2.绘…...
ubuntu开启黑屏现象解决
文章目录 前言一、问题描述二、解决方案1. 检查显卡驱动解决步骤: 2. 修复 GRUB 配置解决步骤: 3. 使用恢复模式解决步骤: 三、验证与总结 前言 在使用 Ubuntu 操作系统时,一些用户可能会遇到开机后屏幕黑屏的现象。这种问题可能…...
深度学习deeplearn3
# Jupyter Notebook魔法命令,用于在Notebook中内联显示图表 %matplotlib inline# 导入NumPy库,用于高效的数值计算 import numpy as np# 从matplotlib_inline库导入backend_inline模块,用于设置图表显示格式 from matplotlib_inline import b…...
Mac强制解锁APP或文件夹
当Mac安装过火绒企业版、云安全访问服务之类的APP需要卸载的时候,会发现需要管理员密码,正常的卸载流程走不下去,直接删除APP,会提示“不能完成此操作,xxx已锁定”的信息,此处就记录一下如何关闭锁定状态&a…...
android开发:zxing-android-embedded竖屏扫描功能
Android 点击按钮调用竖屏二维码扫描 提示:zxing-android-embedded插件已过时,建议更换别的。 场景:Home页面上有个扫描按钮,点击后打开摄像头完成扫描功能,扫描时要求竖屏。 方案:使用zxing-android-embe…...
SQL语句(二)—— DML
目录 一、添加数据 1、给指定字段添加数据 2、给全部字段添加数据 3、批量添加数据 二、修改数据 1、修改数据的具体语法 2、案例分析 3、注意事项 三、删除数据 1、删除数据的具体语法 2、案例 3、注意事项 DML全称是Data Manipulation Language,即数据…...
2.2 路径问题专题:LeetCode 63. 不同路径 II
动态规划解决LeetCode 63题:不同路径 II(含障碍物) 1. 题目链接 LeetCode 63. 不同路径 II 2. 题目描述 一个机器人位于 m x n 网格的左上角,每次只能向右或向下移动一步。网格中可能存在障碍物(标记为 1ÿ…...
Linux系统程序设计:从入门到高级Day02
这一篇 我带大家复习一下,C语言中的文件 那一部分 大家注意 这里的图并非原创 是当时我老师的图片 本片作用主要是 后续会有文件相关操作,这篇帮大家复习C语言文件中的内容 有助于大家后面的理解。 文章中代码大多是图片格式,是因为这是我…...
2025高频面试设计模型总结篇
文章目录 设计模型概念单例模式工厂模式策略模式责任链模式 设计模型概念 设计模式是前人总结的软件设计经验和解决问题的最佳方案,它们为我们提供了一套可复用、易维护、可扩展的设计思路。 (1)定义: 设计模式是一套经过验证的…...
【LeetCode 热题100】208:实现 Trie (前缀树)(详细解析)(Go语言版)
🚀 力扣热题 208:实现 Trie (前缀树)(详细解析) 📌 题目描述 力扣 208. 实现 Trie (前缀树) Trie(发音类似 “try”)是一种树形数据结构,用于高效地存储和检索字符串集合中的键。实…...
CSS 父类元素的伪类 选择器
父元素的 :hover 状态可以影响子元素的样式。当父元素处于 :hover 状态时,可以通过 CSS 的选择器为子元素设置样式。 .parent:hover .child 这种选择器叫做 后代选择器(Descendant Selector) ,结合了 :hover 伪类。它的作用是&…...
目前来讲 有哪些三维重建算法,哪个算法效果好
三维重建是计算机视觉和图形学的重要研究方向,其算法在不同场景下的效果差异较大。以下是当前主流的三维重建算法及其特点,按技术路线分类整理: 1. 传统几何方法 (1)结构光(Structured Light…...
快速掌握MCP——Spring AI MCP包教包会
最近几个月AI的发展非常快,各种大模型、智能体、AI名词和技术和框架层出不穷,作为一个业余小红书博主的我最近总刷到MCP这个关键字,看着有点高级我也来学习一下。 1.SpringAI与functionCall简单回顾 前几个月我曾写过两篇关于SpringAI的基础…...
KUKA机器人查看运行日志的方法
对于KUKA机器人的运行日志都是可以查看和导出的,方便查找问题。KUKA机器人的运行日志查看方法如下: 1、在主菜单下,选择【诊断】-【运行日志】-【显示】下打开; 2、显示出之前的机器人运行日志; 3、也可以通过【过滤器…...
MySQL 基础使用指南-MySQL登录与远程登录
MySQL 基础使用指南 1. 登录 MySQL 数据库的命令解析 命令格式: mysql -u用户名 -p密码参数说明: -u(user 的缩写):指定登录用户。例如 -uroot 表示以 root 用户登录。-p(password 的缩写)&a…...
web-ui windows安装与配置
web-ui windows安装与配置 安装然后安装依赖 运行配置 安装 git clone https://github.com/browser-use/web-ui.git先把clone下来 需要有python环境 最好是 Python 3.11 这里就不赘述了 然后安装依赖 pip install -r requirements.txt运行 python webui.py --ip 127.0.0.1 …...
游戏引擎学习第201天
仓库:https://gitee.com/mrxiao_com/2d_game_5 回顾之前的内容,并遇到了一次一阶异常(First-Chance Exception)。 欢迎来到新一期的开发过程,我们目前正在编写调试接口代码。 当前,我们已经在布局系统上进行了一些工…...
