位置: IT常识 - 正文

微服务 Spring Boot Mybatis-Plus 整合 EasyPOI 实现 Excel 一对多 导入(微服务springboot结构)

编辑:rootadmin
微服务 Spring Boot Mybatis-Plus 整合 EasyPOI 实现 Excel 一对多 导入 文章目录⛄引言一、EasyPOI 实现Excel 的一对多导入 -- 代码实现⛅需求说明⚡核心源码实现二、Easy POI 实现一对多导入 -- 测试三、效果图展示⛵小结⛄引言

推荐整理分享微服务 Spring Boot Mybatis-Plus 整合 EasyPOI 实现 Excel 一对多 导入(微服务springboot结构),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:微服务 spring security,微服务springboot结构,微服务 spring mvc,微服务springboot,微服务 spring mvc,微服务 spring,微服务springboot与springcloud,微服务springboot结构,内容如对您有帮助,希望把文章链接给更多的朋友!

Excel导入 是 开发中 很常用的 功能 ,本篇讲解 如何使用 Spring Boot + MyBatis -Plus 整合 EasyPOI 实现Excel 的一对多导入。

EasyPOI官网

一、EasyPOI 实现Excel 的一对多导入 – 代码实现⛅需求说明

采用 微服务 Spring Boot、Mybatis-Plus 整合 EasyPOI 实现Excel的一对多导入

Excel 导入 实现详细细节

前端采用 Vue+ElementUI 实现导入页面展示,要求弹出上传框、 展示导入模板、 并且要求文件手动上传后端导入 要求实现EasyPOI实现、采用工具类完成导入的集合映射要求使用 Mybatis-Plus 实现 批量导入⚡核心源码实现

Excel 一对多导入如下所示

以上的商品信息该如何进行映射呢?

EasyPOI为我们提供了专门的映射集合的注解,@ExcelCollection

表示一个集合,主要针对一对多的导出,比如一个老师对应多个科目,科目就可以用集合表示

采用 注解进行映射即可

后端源码

SysUserExcel

package com.chen.excel;import cn.afterturn.easypoi.excel.annotation.Excel;import cn.afterturn.easypoi.excel.annotation.ExcelCollection;import com.chen.entity.GoodsEntity;import lombok.Data;import java.util.Date;import java.util.List;@Datapublic class SysUserExcel { @Excel(name = "序号", orderNum = "0", format = "isAddIndex") private Integer index = 1; @Excel(name = "用户账号 *") private String username; @Excel(name = "真实姓名 *") private String realName; @Excel(name = "用户性别 *", replace = {"男_1", "女_2"}) private Integer gender; @Excel(name = "电子邮箱", width = 25) private String email; @Excel(name = "手机号码 *") private String mobile; // 注解映射商品信息集合 @ExcelCollection(name = "商品信息") private List<GoodsExcel> goodsList;}

GoodsExcel

package com.chen.excel;import cn.afterturn.easypoi.excel.annotation.Excel;import cn.afterturn.easypoi.excel.annotation.ExcelCollection;import com.chen.entity.GoodsEntity;import lombok.Data;import java.util.List;@Datapublic class GoodsExcel { @Excel(name = "商品编号", orderNum = "0", format = "isAddIndex") private Integer index = 1; @Excel(name = "商品名称") private String goodsName; @Excel(name = "商品价格") private Double goodsPrice; @Excel(name = "收货地址") private String address;}

SysUserService

public interface SysUserService extends IService<SysUserEntity> { ResultBean<PageInfo<SysUserDTO>> page(SysUserDTO param); ResultBean<Integer> insert(SysUserDTO param); ResultBean<Integer> importExcel(MultipartFile file);}

SysUserServiceImpl

@Overridepublic ResultBean<Integer> importExcel(MultipartFile file) { ImportParams importParams = new ImportParams(); //标题行设置为1行,默认是0,可以不设置;依实际情况设置。 importParams.setTitleRows(0); // 表头设置为1行 importParams.setHeadRows(2); try { //读取excel List<SysUserExcel> sysUserExcelList = ExcelImportUtil.importExcel(file.getInputStream(), SysUserExcel.class, importParams); batchInsert(sysUserExcelList); return ResultBean.create(0, "success"); } catch (Exception e) { log.error("导入 Excel 异常! e ==> {}", e); return ResultBean.create(10, "导入excel 异常!"+e.getMessage()); }}public void batchInsert(List<SysUserExcel> param) throws Exception{ //1.转换为dto集合 List<SysUserEntity> sysUserEntityList = BeanUtil.copyToList(param, SysUserEntity.class); //2.转换为商品实体集合 List<GoodsEntity> goodsEntityList = BeanUtil.copyToList(param.get(0).getGoodsList(), GoodsEntity.class); //3.转换集合 sysUserEntityList.stream().filter(obj -> obj.getUsername() != null) .forEach(obj -> obj.setPassword("123")); //4.批量保存 saveBatch(sysUserEntityList); // 保存用户id至商品id sysUserEntityList.stream().forEach(obj -> { goodsEntityList.stream().forEach(goods -> { goods.setUserId(obj.getId()); }); }); goodsService.saveBatch(goodsEntityList);}微服务 Spring Boot Mybatis-Plus 整合 EasyPOI 实现 Excel 一对多 导入(微服务springboot结构)

商品业务类

GoodsEntity

@Data@TableName("tb_goods")public class GoodsEntity { private Long id; private Long userId; private String goodsName; private Double goodsPrice; private String address; private Date createTime; private Date updateTime;}

GoodsService

import com.baomidou.mybatisplus.extension.service.IService;import com.chen.entity.GoodsEntity;/** * @author whc */public interface GoodsService extends IService<GoodsEntity> {}

GoodsServiceImpl

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;import com.chen.entity.GoodsEntity;import com.chen.mapper.GoodsMapper;import com.chen.service.GoodsService;import lombok.extern.slf4j.Slf4j;import org.springframework.stereotype.Service;/** * @author whc */@Slf4j@Servicepublic class GoodsServiceImpl extends ServiceImpl<GoodsMapper, GoodsEntity> implements GoodsService {}

前端源码

SysUserList Vue 部分

<el-dialog :visible.sync="userVisibleOnly" width="780px" title="新增/编辑"> <el-form :model="sysUser" :rules="rules" ref="sysUserForm" label-width="120px"> <el-row> <el-form-item style="font-weight: bold" label="模板下载"> <el-button type="text">导入用户模板</el-button> </el-form-item> </el-row> <el-row> <el-form-item style="font-weight: bold" label="相关附件"> <el-upload class="upload-demo" :action="importUrl" :on-success="uploadSuccess" accept=".xlsx" ref="upload" multiple :limit="3" :auto-upload="false" :on-exceed="handleExceed"> <el-button type="primary" icon="el-icon-upload2" size="small">导入</el-button> </el-upload> <!-- <el-button type="primary" size="small">点击上传</el-button>--> </el-form-item> </el-row> </el-form> <span slot="footer" class="dialog-footer"> <el-button type="primary" size="mini" @click="clkBtnUpload">确定</el-button> <el-button type="warning" size="mini" @click="userVisibleOnly = false">取消</el-button> </span></el-dialog>

SysUserList JS 部分

data(){return:{userVisibleOnly: false}}metheds:{uploadSuccess(val) { if (val.code == 0) { this.$message.success("导入成功~"); this.getSysUserList(); } }, handleExceed(val) { }, clkBtnUpload() { this.submitUpload(); this.$message({ showClose: true, message: '上传成功,正在导入...' }); this.userVisibleOnly = false; }, submitUpload() { this.$refs.upload.submit(); },}

代码编写完毕,进行测试

二、Easy POI 实现一对多导入 – 测试

启动后端、前端 访问 : 127.0.0.1:80

导入测试

导入采用手动导入,点击确定后,将表单提交至后端

断点进入

我们看到已经完成了对象映射,直接进行映射对象,插入数据库即可

扩展知识:IDEA 断点快捷键 f8 按行进行断点调试、f9 进入下一次断点位置,若没有,直接结束

三、效果图展示

⛵小结

以上就是【Bug 终结者】对 微服务 Spring Boot Mybatis-Plus 整合 EasyPOI 实现 Excel 一对多 导入 的简单介绍,Excel一对多导入其实如此简单,Excel导入也是很常见的功能,希望带来这个案例,大家可以遇到需求时,进行举一反三,感谢支持!

如果这篇【文章】有帮助到你,希望可以给【Bug 终结者】点个赞👍,创作不易,如果有对【后端技术】、【前端领域】感兴趣的小可爱,也欢迎关注❤️❤️❤️ 【Bug 终结者】❤️❤️❤️,我将会给你带来巨大的【收获与惊喜】💝💝💝!

本文链接地址:https://www.jiuchutong.com/zhishi/298671.html 转载请保留说明!

上一篇:【JavaScript数据结构与算法】字符串类(反转字符串中的单词)(javascript数据类型)

下一篇:openCV实践项目:拖拽虚拟方块(opencv项目开发实战)

  • 移动营销该怎么玩?每个营销人都该看看~(移动营销怎么教)

    移动营销该怎么玩?每个营销人都该看看~(移动营销怎么教)

  • 什么是功放什么是音箱(什么是功放)(功放什么意思?)

    什么是功放什么是音箱(什么是功放)(功放什么意思?)

  • airpods1代左耳连接总断开(airpods1代左耳连不上)

    airpods1代左耳连接总断开(airpods1代左耳连不上)

  • 微信跟随系统在哪设置(微信跟随系统在哪里找)

    微信跟随系统在哪设置(微信跟随系统在哪里找)

  • 相册里的视频一直缓冲(相册里的视频一直转圈)

    相册里的视频一直缓冲(相册里的视频一直转圈)

  • 三年的qq聊天记录能恢复吗(三年的qq聊天记录删除了怎么恢复回来)

    三年的qq聊天记录能恢复吗(三年的qq聊天记录删除了怎么恢复回来)

  • 钉钉看回放老师知道是什么时候看的吗(钉钉看回放老师知道吗?)

    钉钉看回放老师知道是什么时候看的吗(钉钉看回放老师知道吗?)

  • 微信视频号是干嘛的(微信视频号运营)

    微信视频号是干嘛的(微信视频号运营)

  • 微信数据号是什么意思(微信1217数据号)

    微信数据号是什么意思(微信1217数据号)

  • 三星s8多长(2020年三星s8使用感受)

    三星s8多长(2020年三星s8使用感受)

  • 微信把对方删了对方知道吗(微信把对方删了对方还能发消息过来)

    微信把对方删了对方知道吗(微信把对方删了对方还能发消息过来)

  • cpu后面hq是什么意思(cpu后面hq和h)

    cpu后面hq是什么意思(cpu后面hq和h)

  • 美图mp1710是什么型号(美图mp1718是什么型号多少钱)

    美图mp1710是什么型号(美图mp1718是什么型号多少钱)

  • dc插口是什么意思(dc接口有哪几种型号)

    dc插口是什么意思(dc接口有哪几种型号)

  • 手机文件怎么备份(手机文件怎么备份到另一个手机)

    手机文件怎么备份(手机文件怎么备份到另一个手机)

  • 苹果11支持反向无线充电吗(苹果11支持反向充电功能吗)

    苹果11支持反向无线充电吗(苹果11支持反向充电功能吗)

  • pro和pro max区别(苹果pro和promax区别)

    pro和pro max区别(苹果pro和promax区别)

  • iphone x是2k屏吗(苹果x是2k屏吗)

    iphone x是2k屏吗(苹果x是2k屏吗)

  • aae文件可以删除吗(aae文件删除会影响原图片吗)

    aae文件可以删除吗(aae文件删除会影响原图片吗)

  • 6英寸手机有哪些(6英寸手机哪款好)

    6英寸手机有哪些(6英寸手机哪款好)

  • 三星note10上市时间

    三星note10上市时间

  • vivox27有没有红外线感应(vivox27有没有红外线遥控器)

    vivox27有没有红外线感应(vivox27有没有红外线遥控器)

  • 抖音里的视频怎么做的(抖音里的视频怎么发给微信好友)

    抖音里的视频怎么做的(抖音里的视频怎么发给微信好友)

  • 组装电脑/未装系统的新电脑安装win7详细图文教程(电脑没组装好会怎么样)

    组装电脑/未装系统的新电脑安装win7详细图文教程(电脑没组装好会怎么样)

  • 增值税普通发票有什么用
  • 增值税科目及会计处理
  • 营业成本包括哪些费用
  • 免征企业所得税的有
  • 企业所得税清算备案日和结束日怎么填
  • 农业企业增值税纳税实务实训心得
  • 银行开户登记号在哪看
  • 减半征收怎么算
  • 总公司委托分公司工程委托书模板
  • 国外预提税是什么
  • 高速公路通行费怎么计算的
  • 三证合一后没有去税务局登记会怎么样
  • 工程款填入申报表应税服务还是应税劳务一栏?
  • 企业并购重组有哪些
  • 公司购买的商品给别的企业用了,企业所得税能列支吗
  • 固定资产被政府查封
  • 公司之间借款收据要领导签字吗
  • 应收款收不回账务处理
  • boss直聘收费怎么这么贵
  • 工资本月计提下月发放,个税如何计算做账
  • 投资性房地产的后续计量从成本模式转为公允价值模式的
  • 技术开发合同收入包括哪些
  • win10如何关闭自动修复
  • 新成立企业什么时候有财务报表
  • 自来水公司的水压力是多少
  • 鸿蒙系统公测版和beta版有什么区别
  • 公司股权转让怎么操作
  • 上个月做的无票收入,这个月开票怎样做分录
  • ps命令不可用
  • win11发布时间正式确定
  • 计提房租记什么科目
  • 撤销与恢复快捷键分别是什么
  • PHP:pg_lo_seek()的用法_PostgreSQL函数
  • 空调拆卸安装怎么找师傅
  • 房地产企业营改增是哪一年
  • qiankun跨域问题
  • 浅谈当下火热的行业
  • php curlfile
  • php框架自动加载
  • 个人怎么开专票
  • 小规模增值税结转账务处理
  • 所得税主要特点有
  • 水利建设专项收入的税率是多少?
  • 代扣代缴个人社保账务处理
  • 企业收取的罚款需要交企业所得税吗
  • 织梦怎么改文字
  • 收到退回的企业所得税分录
  • 季报利润总额怎么算
  • 增值税扣税凭证不包括
  • sqlserver并发怎么处理
  • 保税仓库税收政策
  • 职工体检费用标准规定
  • 资产减值准备的计提影响递延所得税资产吗
  • 应收款和实收款区别
  • 工厂加工费如何计算
  • 利息收入如何开票
  • 研究费用怎么做账
  • 厨师的工资计入什么费用
  • 请演员的费用账务处理
  • 塑料行业税负率是多少
  • mysql子查询嵌套查询
  • 误删了分区怎么恢复
  • linux CentOS/redhat 6.5 LVM分区使用详解
  • linux kill-15
  • android自定义搜索框
  • 命令以管理员运行
  • perl -p -i
  • [置顶]星陨计划
  • 简介英文
  • pycharm新手使用教程
  • python模块怎么用
  • js foreach倒序
  • javascript调用c语言
  • 医院体检怎么拿发票
  • 怎么在晋江查找观看记录
  • 苏宁易购的联系电话
  • 国家税务局何时上班
  • 广告发布合同属于什么合同
  • 对外销售产品
  • 湖南自然人电子税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设