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

【Spring+MyBatis】_图书管理系统(下篇)

图书管理系统上篇、中篇如下:

【Spring+MyBatis】_图书管理系统(上篇)-CSDN博客

【Spring+MyBatis】_图书管理系统(中篇)-CSDN博客


目录

功能5:删除图书

6.1 约定前后端交互接口

6.2 后端接口

6.3 前端页面

6.4 单元测试

功能6:批量删除图书

7.1 约定前后端交互接口

7.2 后端接口

7.3 前端页面

7.4 单元测试


功能5:删除图书

6.1 约定前后端交互接口

接口定义:/Book/deleteBook;

参数:id;

返回内容:字符串。为空则表示删除成功,不为空则表示删除失败,并返回错误信息;

采用逻辑删除方式,即通过update操作实现,具体做法是将status置为0,令前端页面无法获取

接口定义:/Book/updateBook;

参数:id,status;

返回内容:字符串。为空则表示删除成功,不为空则表示删除失败,并返回错误信息;

6.2 后端接口

BookController类和BookService类中均无需新增方法,通过updateBook实现;

BookInfoMapper接口也无需新增方法声明,

仅需在单元测试后端接口时根据updateBook方法的对应路由并传递id和status=0;

在编写前端页面时将ajax的url置为updateBook方法的对应路由即可;

6.3 前端页面

在book_list.html页面增加:

 function deleteBook(bookId) {var isDelete = confirm("确认删除?");if (isDelete) {//删除图书$.ajax({type:"post",url: "/Book/updateBook",data: {id:bookId,status:0},success: function(result){if(result == ""){//    删除成功location.href="book_list.html";}else{//    删除失败alert(result);}}})}}

6.4 单元测试

1、通过Postman测试后端接口:

查看前端页面图书列表信息:

可见id=13的图书信息已经在前端页面不可见,

在服务器端查看日志:

查看数据库图书信息:

可见该图书信息并未真正删除,且status被置为0;

2、测试前端页面:

删除id=11的图书信息:

在数据库中查看图书信息:

可见数据库中该图书信息并未删除,且status被置为0;

功能6:批量删除图书

7.1 约定前后端交互接口

同功能5的删除单个图书即单个更新图书状态的思路,批量删除图书就是批量更新图书状态;

但当前实现的updateBook方法仅支持一个id作为参数,即接口不可复用,需单独编写接口;

接口定义:/Book/batchDelete;

参数:List<Integer> ids;

返回内容:字符串。为空则表示删除成功,不为空则表示删除失败,并返回错误信息;

7.2 后端接口

在BookController类中增加相关方法:

@RequestMapping("/batchDelete")public String batchDelete(@RequestParam List<Integer> ids){log.info("接收批量删除图书请求: 图书id:{}",ids);Integer  result=bookService.batchDelete(ids);if(result <=0){log.error("批量删除失败,图书id:{}",ids);return "批量删除失败,请联系管理员";}return "";}

在BookService类中增加相关方法:

    public Integer batchDelete(List<Integer> ids){Integer result=0;try{result=bookInfoMapper.batchDelete(ids);}catch (Exception e){log.error("批量删除图书失败:e{}",e);}return result;}

在BookInfoMapper接口中增加相关方法声明:

    Integer batchDelete(@Param("ids") List<Integer> ids);

为batchDelete方法配置对应xml文件的<update>标签:

<update id="batchDelete">update book_infoset status=0where id in<foreach collection="ids" item="id" open="(" close=")" separator=",">#{id}</foreach></update>

注:使用集合作为参数时,若直接将元素用逗号连接作为参数传递会报错:

在Spring MVC传参部分曾有介绍,需使用@RequestParam注解:

【JavaEE】_Spring MVC项目使用数组与集合传参_java传参集合-CSDN博客文章浏览阅读1.2k次,点赞34次,收藏20次。本文介绍了在SpringMVC项目中如何使用数组和List接口进行参数传递,包括单个和多个同名参数处理,以及urlencode的应用。同时讲解了@RequestParam注解的使用,以确保正确接收和解析参数。 https://blog.csdn.net/m0_63299495/article/details/136489044

7.3 前端页面

 function batchDelete() {var isDelete = confirm("确认批量删除?");if (isDelete) {//获取复选框的idvar ids = [];$("input:checkbox[name='selectBook']:checked").each(function () {ids.push($(this).val());});console.log(ids);$.ajax({type: "post",url: "/Book/batchDelete?ids="+ids,success: function (result) {if(result == ""){//    删除成功location.href="book_list.html";}else{//    删除失败alert(result);}}});}}

7.4 单元测试

1、测试后端接口:

可在前端页面进行检查:

可见id为5和6的图书已经不可见;

查看服务器日志:

通过数据库查看图书信息:

可见id为5和6的图书的状态被置为0,且并未从数据库中删除;

2、测试前端页面:

查看服务器处日志:

 通过数据库查看id为5和6的图书信息,可见其status被置为0但并未从数据库删除:

相关文章:

【Spring+MyBatis】_图书管理系统(下篇)

图书管理系统上篇、中篇如下&#xff1a; 【SpringMyBatis】_图书管理系统&#xff08;上篇&#xff09;-CSDN博客 【SpringMyBatis】_图书管理系统&#xff08;中篇&#xff09;-CSDN博客 目录 功能5&#xff1a;删除图书 6.1 约定前后端交互接口 6.2 后端接口 6.3 前端…...

若依-@Excel新增注解numberFormat

Excel注解中原本的scale会四舍五入小数&#xff0c;导致进度丢失 想要的效果 显示的时候保留两个小数真正的数值是保留之前的数值 还原过程 若以中有一個專門的工具类&#xff0c;用来处理excel的 找到EXCEL导出方法exportExcel()找到writeSheet,写表格的方法找到填充数据的方法…...

Cherry-Studio下载安装教程,AI面向开发者的工具或平台(付安装包)

文章目录 一、Cherry Studio是什么&#xff1f;二、功能特点 一、Cherry Studio是什么&#xff1f; Cherry Studio 是一款开源跨平台的多模型服务桌面客户端&#xff0c;集成超 300 个大语言模型&#xff0c;内置 300 多个预配置 AI 助手&#xff0c;支持多格式文件处理、全局…...

多信道接收机

线性调频&#xff08;LFM&#xff09;信号&#xff0c;模拟多个目标反射的回波信号&#xff0c;并进行混频和滤波处理。 % 参数设置 c 3e8; % 光速 (m/s) f0 8.566e9; % 载波频率 (Hz) T 10e-6; % 脉冲持续时间 (s) B 100e6; % 信号带宽 (Hz) mu B / T; % 调频斜率 (Hz/s…...

修改项目的一些前端记录(自用)

<div style"background:#f2f2f2;position:absolute;top:75px;width:10%;bottom:0px">\<ol class"tree">\<li>\<label for"folder1" class"folderOne foldertop"><img src"common/img/时间.png" …...

阿里云虚机的远程桌面登录提示帐户被锁定了

提示由于安全原因&#xff0c;帐户被锁定。 阿里云虚机ECS的远程桌面登录提示帐户被锁定了&#xff0c;只能登录阿里云处理 阿里云-计算&#xff0c;为了无法计算的价值 需选择通过VNC连接 然后计算机管理&#xff0c;解除帐户锁定即可。...

AD(Altium Designer)器件封装——立创商城导出原理图和PCB完成器件封装操作指南

1、立创商城下载原理图和PCB图 1.1 打开立创商城 官网:www.SZLCSC.COM 1.2 寻找所需器件 以芯片为例 器件类——>芯片类——>对应芯片 1.3 确定所需芯片 确定芯片——>数据手册 1.4 打开原理图和PCB图 1:原理图 2:PCB 3:打开 1.5 导出原理图 操作...

【DeepSeek系列】04 DeepSeek-R1:带有冷启动的强化学习

文章目录 1、简介2、主要改进点3、两个重要观点4、四阶段后训练详细步骤4.1 冷启动4.2 推理导向的强化学习4.3 拒绝采样和有监督微调4.4 针对所有场景的强化学习 5、蒸馏与强化学习对比6、评估6.1 DeepSeek-R1 评估6.2 蒸馏模型评估 7、结论8、局限性与未来方向 1、简介 DeepS…...

【C++八股】野指针和悬空指针

野指针&#xff08;Wild Pointer&#xff09;是指未被初始化或指向非法内存地址的指针。在 C/C 等语言中&#xff0c;指针变量如果在定义时未被初始化&#xff0c;其值是随机的&#xff0c;可能指向任意内存位置&#xff0c;这种指针被称为野指针。使用野指针进行解引用操作会导…...

Mac 清理缓存,提高内存空间

步骤 1.打开【访达】 2.菜单栏第五个功能【前往】&#xff0c;点击【个人】 3.【command shift J】显示所有文件&#xff0c;打开【资源库】 4.删除【Containers】和【Caches】文件 Containers 文件夹&#xff1a;用于存储每个应用程序的沙盒数据&#xff0c;确保应用程序…...

fpga助教面试题

第一题 module sfp_pwm( input wire clk, //clk is 200M input wire rst_n, input wire clk_10M_i, input wire PPS_i, output reg pwm ) reg [6:0] cunt ;always (posedge clk ) beginif(!rst_n)cunt<0;else if(cunt19) //200M是10M的20倍cunt<0;elsecunt<cunt1;…...

DeepSeek与ChatGPT:会取代搜索引擎和人工客服的人工智能革命

云边有个稻草人-CSDN博客 在众多创新技术中&#xff0c;DeepSeek和ChatGPT无疑是最为引人注目的。它们通过强大的搜索和对话生成能力&#xff0c;能够改变我们与计算机交互的方式&#xff0c;帮助我们高效地获取信息&#xff0c;增强智能服务。本文将深入探讨这两项技术如何结合…...

有没有其他技术可以替代本地 RAG?

知识图谱 原理&#xff1a;知识图谱是一种结构化的语义网络&#xff0c;用于描述实体之间的关系。它以图的形式表示知识&#xff0c;节点代表实体&#xff0c;边代表实体之间的关系。通过知识图谱&#xff0c;模型可以直接获取结构化的知识&#xff0c;从而生成更准确和相关的回…...

【强化学习】Q-learning算法详解:含MATLAB和Python实现代码

Q-learning算法详解 1. Q-learning算法简介Q-Learning算法的基本概念Q-Learning算法的核心思想Q-learning算法步骤Q-Learning算法的特点 MATLAB 实现 Q-learningPython 实现 Q-learning参考 强化学习属于机器学习&#xff0c;但与以前的监督学习和无监督学习的处理对象和任务都…...

Java 多数据源时事务回滚问题

目录 问题描述 1、Atomikos事务管理器 2、MyBatis-Plus多数据源支持 dynamic-datasource 特性 约定 使用方法 mybatis-mate 特性 使用方法 问题描述 在多数据源的情况下&#xff0c;如果一个事务跨越多个数据源&#xff0c;当其中一个数据源的操作失败时&#xff0c;我…...

怎麼防止爬蟲IP被網站封鎖?

隨著越來越多的網站加強其反爬蟲措施&#xff0c;爬蟲IP被封鎖成為了常見的問題。如何有效地避免IP被封&#xff0c;從而讓數據採集工作更加順利&#xff1f; 常見的反爬策略包括&#xff1a; 頻率限制&#xff1a;設置請求頻率&#xff0c;對於發出請求過於頻繁的IP進行封鎖…...

DeepSeek + Claude 提升效果

案例1&#xff1a;分布式锁 问题 spring boot 和 mybatis 实现分布式锁 Deepseek R1 思考过程 嗯&#xff0c;用户问的是如何在Spring Boot和MyBatis中实现分布式锁。首先&#xff0c;我得回忆一下分布式锁的基本概念。分布式锁是为了在分布式系统中协调多个服务实例对共享…...

使用html css js 开发一个 教育机构前端静态网站模板

这个教育机构网站模板是专为前端开发初学者设计的练习项目&#xff0c;适合正在学习前端的学生或自学者使用。网站内容包括首页、课程体系、师资力量、关于我们和联系我们等基础页面&#xff0c;帮助学习者熟悉网页布局、样式设计和交互功能的实现。 静态页面 简单截图 应用…...

ranges::set_intersection set_union set_difference set_symmetric_difference

std::ranges::set_intersection&#xff1a;是 C20 引入的一个算法&#xff0c;用于计算两个已排序范围的交集。它将两个范围的交集元素复制到输出范围中。 std::ranges::set_intersection 用于计算两个已排序范围的交集。它将两个范围的交集元素复制到输出范围中。 注意事项…...

在IDEA的Maven中(同步所有Maven项目)和(重新加载所有Maven项目)的区别

特性同步所有 Maven 项目 (Sync All Maven Projects)重新加载所有 Maven 项目 (Reload All Maven Projects)主要作用使 IDEA 项目结构、依赖关系与 pom.xml 文件同步。强制重新读取所有 pom.xml 文件&#xff0c;并重建 IDEA 的 Maven 项目模型。缓存使用 IDEA 缓存的 Maven 项…...

如何查询网站是否被百度蜘蛛收录?

一、使用site命令查询 这是最直接的方法。在百度搜索框中输入“site:你的网站域名”&#xff0c;例如“site.com”&#xff08;请将“example.com”替换为你实际的网站域名&#xff09;。如果搜索结果显示了你的网站页面&#xff0c;并且显示了收录的页面数量&#xff08;如“…...

el-table树状表格,默认展开第一个节点的每一层

效果如图 <template><el-table:data"tableData"style"width: 100%":tree-props"{ children: children, hasChildren: hasChildren }":expand-row-keys"expandRowKeys"row-key"id"expand-change"handleExpan…...

express-validator 数据校验详解

express-validator 是一个用于在 Express 应用中进行数据验证和清理的中间件。 一、安装 # 使用 npm 安装npm install express-validator 二、基本使用 1. 引入和初始化 const express require("express");const { body, validationResult } require("ex…...

使用VSCODE开发C语言程序

使用vscode配置C语言开发环境 一、安装VSCODE 1、下载vscode ​ 从官方网站&#xff08;https://code.visualstudio.com/Download&#xff09;上&#xff0c;下载windows版本的vscode 2、安装vscode ​ 下载完毕后&#xff0c;按照提示进行安装即可&#xff08;尽可能不要安…...

Python学习心得常用的内置函数

常用的内置函数&#xff1a; 1.数据类型转换函数&#xff1a; 描述说明 描述说明 bool(obj) 获取指定对象 obj 的布尔值 str(obj) 将指定对象 obj 转成字符串类型 int(x) 将 x 转成 int 类型 float(x) 将 x 转成 float 类型 list(sequence) 将序列转成列表类型 tu…...

【数据结构初阶第十二节】设计循环队列

云边有个稻草人-CSDN博客 必须有为成功付出代价的决心&#xff0c;然后想办法付出这个代价。 还有最后一道关于队列的习题&#xff0c;这题有点难&#xff0c;准备好迎接挑战吧&#xff01; 目录 1.【题目】 2.实现循环队列推荐用数组&#xff0c;Why? 3.Q1&#xff1a;如…...

【数据分享】1929-2024年全球站点的逐年降雪深度数据(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、能见度等指标&#xff0c;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 有关气象指标的监测站点数据&#xff0c;之前我们分享过1929-2024年全球气象站…...

【强化学习的数学原理】第10课-Actor-Critic方法-笔记

学习资料&#xff1a;bilibili 西湖大学赵世钰老师的【强化学习的数学原理】课程。链接&#xff1a;强化学习的数学原理 西湖大学 赵世钰 文章目录 一、最简单的Actor-Critic&#xff08;QAC&#xff09;二、Advantage Actor-Critic&#xff08;A2C&#xff09;三、重要性采样和…...

scratch猜年龄互动小游戏 2024年12月scratch四级真题 中国电子学会 图形化编程 scratch四级真题和答案解析

scratch猜年龄互动小游戏 2024年12月电子学会图形化编程Scratch等级考试四级真题 一、题目要求 老爷爷的年龄是1-100的随机数,老爷爷询问“请猜猜我的年龄是多少?”,输入年龄,老爷爷会回答"大了"或者"小了,直到最后成功猜出年龄。 1、准备工作 (1)删…...

javaSE学习笔记23-线程(thread)-总结

创建线程的三种方式 练习代码 package com.kuang.thread;import java.util.concurrent.Callable; import java.util.concurrent.ExecutionException; import java.util.concurrent.FutureTask;//回顾总结线程的创建 public class ThreadNew {public static void main(String[…...