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

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

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

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


目录

功能5:删除图书

[6.1 约定前后端交互接口](#6.1 约定前后端交互接口)

[6.2 后端接口](#6.2 后端接口)

[6.3 前端页面](#6.3 前端页面)

[6.4 单元测试](#6.4 单元测试)

功能6:批量删除图书

[7.1 约定前后端交互接口](#7.1 约定前后端交互接口)

[7.2 后端接口](#7.2 后端接口)

[7.3 前端页面](#7.3 前端页面)

[7.4 单元测试](#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页面增加:

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类中增加相关方法:

java 复制代码
@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类中增加相关方法:

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

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

java 复制代码
    Integer batchDelete(@Param("ids") List<Integer> ids);

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

java 复制代码
<update id="batchDelete">
        update book_info
        set status=0
        where 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 前端页面

java 复制代码
 function batchDelete() {
                var isDelete = confirm("确认批量删除?");
                if (isDelete) {
                    //获取复选框的id
                    var 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但并未从数据库删除:

相关推荐
givemeacar6 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
小江的记录本9 小时前
【Bean】JavaBean(原生规范)/ Spring Bean 【重点】/ 企业级Bean(EJB/Jakarta Bean)
java·数据库·spring boot·后端·spring·spring cloud·mybatis
bearpping10 小时前
Spring Boot 整合 MyBatis 与 PostgreSQL 实战指南
spring boot·postgresql·mybatis
不吃香菜学java11 小时前
苍穹外卖-菜品分页查询
数据库·spring boot·tomcat·log4j·maven·mybatis
java修仙传11 小时前
数据库和缓存的一致性如何保证?
redis·mysql·mybatis
不吃香菜学java12 小时前
苍穹外卖-新增菜品代码开发
spring boot·spring·servlet·log4j·maven·mybatis
qq_3340602113 小时前
spring_springmvc_mybatis权限控制+boostrap实现UI
java·spring·mybatis
深蓝轨迹14 小时前
黑马点评-day02-缓存笔记
redis·笔记·缓存·mybatis
小江的记录本14 小时前
【Spring Boot】Spring Boot 全体系知识结构化拆解(附 Spring Boot 高频面试八股文精简版)
java·spring boot·后端·spring·面试·tomcat·mybatis
Thomas.Sir14 小时前
从底层源码深入剖析 MyBatis 工作原理
java·架构·mybatis