《尚品甄选》:后台系统——权限管理之分类和品牌管理,使用EasyExcel导入导出数据(debug一遍)

本文主要是介绍《尚品甄选》:后台系统——权限管理之分类和品牌管理,使用EasyExcel导入导出数据(debug一遍),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、分类管理
    • 1.1 表结构介绍
    • 1.2 分类列表查询
  • 二、EasyExcel使用
    • 2.1 EasyExcel简介
    • 2.2 导出功能
    • 2.3 导入功能
  • 三、品牌管理
    • 3.1 表结构介绍
    • 3.2 列表查询
    • 3.3 添加品牌
    • 3.4 修改品牌
    • 3.5 删除品牌

一、分类管理

分类管理就是对商品的分类数据进行维护。

在这里插入图片描述

1.1 表结构介绍

分类数据所对应的表结构如下所示,分类数据是具有层级结构的

CREATE TABLE `category` (`id` bigint NOT NULL AUTO_INCREMENT COMMENT '分类id',`name` varchar(50) DEFAULT NULL COMMENT '分类名称',`image_url` varchar(200) DEFAULT NULL,`parent_id` bigint DEFAULT NULL COMMENT '父分类id',`status` tinyint DEFAULT NULL COMMENT '是否显示[0-不显示,1显示]',`order_num` int DEFAULT NULL COMMENT '排序',`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',`is_deleted` tinyint NOT NULL DEFAULT '0' COMMENT '删除标记(0:可用 1:不可用)',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9992 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='商品分类'

1.2 分类列表查询

需求分析:
当页面初始化完毕以后,此时请求后端接口查询所有的一级分类数据,一级分类数据的parent_id为0。当用户点击某一个分类前的小箭头,那么此时就需要查询该分类下所对应的所有的子分类数据,是一种懒加载实现方式。

话不多说,让我们来debug一遍:首先来到controller层,拿到前端传来的第一级id值
在这里插入图片描述
进入业务层,根据id值从数据库中查询数据,可以看到,我这里有10条数据
在这里插入图片描述
下图的for循环是用来判断该分类下是否有子节点,有子节点就设置字段hasChildren为true;前端根据hasChildren的值来展示样式。
在这里插入图片描述
对应的两个SQL语句如下:

@Mapper
public interface CategoryMapper {@Select("select * from category where parent_id = #{parentId} and is_deleted = 0 order by id desc")List<Category> selectByParentId(Long parentId);@Select("select count(*) from category where parent_id = #{id} and is_deleted = 0")int countByParentId(Long id);
}

二、EasyExcel使用

后台管理系统是管理、处理企业业务数据的重要工具,在这样的系统中,数据的导入和导出功能是非常重要的,其主要意义包括以下几个方面:

  • 提高数据操作效率:手动逐条添加或修改数据不仅费时费力,而且容易出错,此时就可以将大量数据从Excel等表格软件中导入到系统中,通过数据导入功能,可以直接将表格中的数据批量导入到系统中,提高了数据操作的效率。

  • 实现数据备份与迁移:通过数据导出功能,管理员可以将系统中的数据导出为 Excel 或其他格式的文件,以实现数据备份,避免数据丢失。同时,也可以将导出的数据文件用于数据迁移或其他用途。

  • 方便企业内部协作:不同部门可能会使用不同的系统或工具进行数据处理,在这种情况下,通过数据导入和导出功能,可以方便地转换和共享数据,促进企业内部协作。


2.1 EasyExcel简介

官网地址:https://easyexcel.opensource.alibaba.com/

EasyExcel 的主要特点如下:

  • 高性能:EasyExcel 采用了异步导入导出的方式,并且底层使用 NIO 技术实现,使得其在导入导出大数据量时的性能非常高效。

  • 易于使用:EasyExcel 提供了简单易用的 API,用户可以通过少量的代码即可实现复杂的 Excel 导入导出操作。

  • 可扩展性好:EasyExcel 具有良好的扩展性,用户可以通过自定义 Converter 对自定义类型进行转换,或者通过继承 EasyExcelListener 来自定义监听器实现更加灵活的需求。

2.2 导出功能

需求说明:
当用户点击导出按钮的时候,此时将数据库中所有分类的数据导出到一个excel文件中,如图所示:

在这里插入图片描述

首先引入依赖:

<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.0</version>
</dependency>

接着定义一个实体类来封装每一行的数据:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class CategoryExcelVo {@ExcelProperty(value = "id" ,index = 0)private Long id;@ExcelProperty(value = "名称" ,index = 1)private String name;@ExcelProperty(value = "图片url" ,index = 2)private String imageUrl ;@ExcelProperty(value = "上级id" ,index = 3)private Long parentId;@ExcelProperty(value = "状态" ,index = 4)private Integer status;@ExcelProperty(value = "排序" ,index = 5)private Integer orderNum;
}

debug看一遍流程,来到controller层
在这里插入图片描述
来到业务层,首先设置响应结果类型,接着查询分类表,可以看到查询到了703条数据
在这里插入图片描述
数据库查询到的数据不是我们需要的数据格式,因此需要将数据库查询到的数据转换成自己定义的CategoryExcelVo类格式。
在这里插入图片描述
SQL语句编写如下:

    @Select("select id, name, image_url, parent_id, status, order_num from category where is_deleted = 0 order by id")List<Category> selectAll();

2.3 导入功能

需求说明:
当用户点击导入按钮的时候,此时会弹出一个对话框,让用户选择要导入的excel文件,选择完毕以后将文件上传到服务端,服务端通过easyExcel解析文件的内容,然后将解析的结果存储到category表中。如下所示:

在这里插入图片描述

通过EasyExcel的操作文档,对于导入功能,我们需要创建监听器类ExcelListener,让其实现ReadListener接口。

public class ExcelListener<T> implements ReadListener<T> {/*** 每隔100条将数据存入数据库*/private static final int BATCH_COUNT = 100;/*** 缓存的数据*/private List<T> cachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);private CategoryMapper categoryMapper;public ExcelListener(CategoryMapper categoryMapper) {this.categoryMapper = categoryMapper;}//每解析一行数据就会调用一次该方法@Overridepublic void invoke(T o, AnalysisContext analysisContext) {cachedDataList.add(o);//达到BATCH_COUNT时,需要去存储一次数据库,防止数据几万条数据在内存,容易OOMif (cachedDataList.size() >= BATCH_COUNT) {saveData();//存储完成,清理listcachedDataList = ListUtils.newArrayListWithExpectedSize(BATCH_COUNT);}}//excel解析完毕以后需要执行的代码,这里也要保存数据,确保最后遗留的数据也存储到数据库@Overridepublic void doAfterAllAnalysed(AnalysisContext analysisContext) {saveData();}//保存数据到数据库private void saveData() {categoryMapper.batchInsert(cachedDataList);}
}

这里的批量插入SQL语句编写如下:

    <!--    <T> void batchInsert(List<T> cachedDataList);--><insert id="batchInsert">insert into category values<foreach collection="cachedDataList" item="item" separator=",">(#{item.id}, #{item.name}, #{item.imageUrl}, #{item.parentId},#{item.status}, #{item.orderNum},now(), now(), 0)</foreach></insert>

创建好监听器,接下来让我们debug,首先来到controller层,接收文件"01.xlsx"

在这里插入图片描述
来到业务层,首先创建监听器类,然后调用read方法读取excel数据。
在这里插入图片描述

三、品牌管理

品牌管理就是对商品所涉及到的品牌数据进行维护。

3.1 表结构介绍

CREATE TABLE `brand` (`id` bigint NOT NULL AUTO_INCREMENT COMMENT 'ID',`name` varchar(100) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci DEFAULT NULL COMMENT '品牌名称',`logo` varchar(255) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci DEFAULT NULL COMMENT '品牌图标',`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',`is_deleted` tinyint NOT NULL DEFAULT '0' COMMENT '删除标记(0:可用 1:不可用)',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='分类品牌'

3.2 列表查询

需求说明:
当品牌管理页面加载完毕以后就向后端发送分页查询请求,后端进行分页查询,返回分页结果数据。

在这里插入图片描述

继续debug,在controller层,接收到分页参数信息
在这里插入图片描述
业务层代码也很简单,分页查询品牌数据,我这里只查到了2条数据
在这里插入图片描述

SQL语句的编写也很容易

    @Select("select * from brand where is_deleted = 0 order by id desc")List<Brand> findByPage();

3.3 添加品牌

需求说明:
用户点击添加按钮,填写表单数据,点击提交按钮,请求后端接口完成数据的保存操作。效果如下所示:
在这里插入图片描述
controller层获取品牌name、logo图片地址
在这里插入图片描述
业务层将数据存入品牌表
在这里插入图片描述
SQL语句编写如下:

    @Insert("insert into brand (name, logo, create_time, update_time, is_deleted)\n" +"values (#{name}, #{logo}, now(), now(), 0)")void save(Brand brand);

3.4 修改品牌

需求说明:
当用户点击修改按钮的时候,对话框中需要将当前行所对应的品牌数据在该表单页面进行展示。当用户在该表单中点击提交按钮的时候那么此时就需要将表单进行提交,在后端需要提交过来的表单数据修改数据库中的即可。
在这里插入图片描述
controller拿到修改的数据,我这里只修改了name字段
在这里插入图片描述
业务层根据实体类,修改品牌表。
在这里插入图片描述
修改操作对应的SQL语句如下:

    <!--    void updateById(Brand brand);--><update id="updateById">update brand set<if test="name != null and name != ''">name = #{name},</if><if test="logo != null and logo != ''">logo = #{logo},</if>update_time = now()whereid = #{id}</update>

3.5 删除品牌

需求说明:
当点击删除按钮的时候此时需要弹出一个提示框,询问是否需要删除数据?如果用户点击是,那么此时向后端发送请求传递id参数,后端接收id参数进行逻辑删除

在这里插入图片描述
来到controller层,获取到要删除品牌的id值
在这里插入图片描述
业务层也同样很简单,简单的更新语句
在这里插入图片描述
SQL编写如下:

    @Update("update brand set is_deleted = 1,update_time = now() where id = #{id}")void deleteById(Long id);

这篇关于《尚品甄选》:后台系统——权限管理之分类和品牌管理,使用EasyExcel导入导出数据(debug一遍)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/432208

相关文章

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息