WebFlux框架下使用EasyExcel导入Excel文件中的数据到数据库

4 篇文章 0 订阅
2 篇文章 0 订阅

一.导入Excel的组件使用阿里的 EasyExcel。

二.controller代码如下:
注释:webflux跟web上传文件有所不同,webflux使用*@RequestPart**注解接受上传的文件。*

    /**
     * 导入用户数据
     * @param file
     * @return
     */
    @PostMapping("/importExcel")
    public RestVO importExcel(@RequestPart(value = "excel") FilePart file){
        return userService.importExcel(file);
    }

三.Serviceimpl的代码块如下,亲测可用:
注释:重点是下方try底下的六行代码的代码,把上传的文件转成byte数组,放到InputStream输入流中,让EasyExcel能读取到。

 /**
     * 用户导入
     * @param file
     * @return
     */
    @Override
    public RestVO importExcel(FilePart file) {
        SysUserExcelListener sysUserExcelListener = new SysUserExcelListener(userService);
        try {
            Mono<byte[]> map = DataBufferUtils.join(file.content())
                    .map(dataBuffer -> dataBuffer.asByteBuffer().array());
            byte[] block = map.block();
            if(ObjectUtils.isEmpty(block)){
                return RestVO.error("请上传Excel文件!");
            }
            InputStream sbs = new ByteArrayInputStream(block);
            EasyExcelFactory.read(sbs, SysUserImportDto.class, sysUserExcelListener).sheet().doRead();
            //失败的个数
            List<ExcelCheckErrDto<SysUserImportDto>> errList = sysUserExcelListener.getErrList();
            //成功的个数
            List<SysUserImportDto> successList = sysUserExcelListener.getSuccessList();
            String title = "导入用户信息完成,失败"+errList.size()+"条," +
                    "成功"+successList.size()+"条";
            ExcelMessage excelMessage = new ExcelMessage();
            excelMessage.setTitle(title);
            if (errList.size() > 0) {
                String errMsgs = "导入失败明细:"+ "\n";
                for(ExcelCheckErrDto<SysUserImportDto> err : errList){
                    errMsgs = errMsgs + err.getErrMsg() + " | ";
                }
                String message = title + "\n" +errMsgs;
                excelMessage.setMsg(message);
            }
            return RestVO.ok(excelMessage);
        } catch (Exception e) {
            e.printStackTrace();
            log.error("导入数据失败:{}",e.getMessage());
        }
        return RestVO.error();
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用EasyExcel提供的读取Excel文件数据的功能,将数据读取到Java程序,然后再使用JDBC将数据插入到数据库。 以下是一个示例代码,演示如何使用EasyExcelExcel文件数据导入到MySQL数据库: ```java // 读取Excel文件数据 String fileName = "example.xlsx"; List<DemoData> dataList = new ArrayList<>(); EasyExcel.read(fileName, DemoData.class, new DemoDataListener(dataList)).sheet().doRead(); // 将数据插入到数据库 String url = "jdbc:mysql://localhost:3306/test?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC"; String username = "root"; String password = "password"; String sql = "INSERT INTO demo_data (id, name, age) VALUES (?, ?, ?)"; try (Connection conn = DriverManager.getConnection(url, username, password); PreparedStatement pstmt = conn.prepareStatement(sql)) { for (DemoData data : dataList) { pstmt.setInt(1, data.getId()); pstmt.setString(2, data.getName()); pstmt.setInt(3, data.getAge()); pstmt.executeUpdate(); } } catch (SQLException e) { e.printStackTrace(); } ``` 其,`DemoData`是一个Java类,用于存储Excel文件数据。`DemoDataListener`是一个实现了EasyExcel监听器接口的类,用于处理读取Excel文件时的事件。在`DemoDataListener`的`invoke`方法,将读取到的数据存储到`dataList`。 在上述代码使用JDBC连接MySQL数据库,并将数据插入到`demo_data`表。你需要根据自己的实际情况修改数据库连接信息和SQL语句。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值