EasyExcel--------将Excel导入数据库

controller

@RequestMapping("/importExcelFile")
    public BaseResponse importExcelFile(@RequestParam("file") MultipartFile uploadFile) {
        return new BaseResponse().success(excelService.importExcelFile(uploadFile));
    }

Service

public BaseResponse importExcelFile (MultipartFile uploadFile){
        try {
            if(uploadFile.isEmpty()){
                return new BaseResponse().error("文件为空,初始化失败");
            }
            if (orgService.getTotalRecordCount() == 0 ){
                ExcelReaderBuilder workBook = EasyExcel.read
                        (uploadFile.getInputStream(), TbOrganization.class, new ExcelListener());
                ExcelReaderSheetBuilder sheet1 = workBook.sheet();
                sheet1.doRead();
                List<TbOrganization> orgList = ExcelListener.getOrgList();
                List<String> collect1 = orgList.stream().map(TbOrganization::getName).distinct().collect(Collectors.toList());
                if(collect1.size()!=orgList.size()){
                    return new BaseResponse().error("excel表内的名称有重复,初始化失败");
                }
                for(TbOrganization org : orgList) {
                    orgService.addOrg(org);
                }
                return new BaseResponse().success("初始化成功");
            }else{
                return new BaseResponse().error("数据库非空,无法使用初始化方法");
            }
        } catch (Exception e) {
            System.out.println("导入失败:" + e.getMessage());
            return new BaseResponse().error("导入失败");
        }
    }

注:这里我的需求时只能使用excel导入初始化,如果表中有数据就无法导入,且excel表中的名称字段不能重复。

ExcelListener:

import java.util.ArrayList;
import java.util.List;


public class ExcelListener extends AnalysisEventListener<TbOrganization> {

    public static List<TbOrganization> orgList = new ArrayList<>();

    @Override
    public void invoke(TbOrganization tbOrganization, AnalysisContext analysisContext) {
        orgList.add(tbOrganization);
        System.out.println("解析到一条数据:" + tbOrganization);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        System.out.println("全部解析完成");
    }
    public static List<TbOrganization> getOrgList() {
        return orgList;
    }
}

​​​​​​​


import com.alibaba.excel.annotation.ExcelProperty;

import java.io.Serializable;

public class TbOrganization implements Serializable {
    //主键
    private Long id;
    @ExcelProperty("id")
    private String idName;
    @ExcelProperty("name")
    private String name;
    @ExcelProperty("code")
    private String code;

    ///。。。。。。其他。。。。。。
}

好的,这是一个比较常见的需求,我可以给你提供一个简单的实现思路。 1. 首先,我们需要在项目中引入 easyExcel 和 mybatis-plus 的依赖。你可以在 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.6</version> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.1.1</version> </dependency> ``` 2. 然后,我们需要定义一个实体类,用于映射 Excel 中的数据。假设我们要导入的是学生信息,我们可以定义一个 Student 类,如下所示: ```java @Data public class Student { @ExcelProperty("姓名") private String name; @ExcelProperty("年龄") private Integer age; @ExcelProperty("性别") private String gender; @ExcelProperty("班级") private String className; } ``` 3. 接下来,我们需要定义一个 Controller,用于接收上传的 Excel 文件,并将数据批量插入到数据库中。代码如下: ```java @RestController @RequestMapping("/import") public class ImportController { @Autowired private StudentService studentService; @PostMapping("/excel") public String importExcel(MultipartFile file) throws Exception { EasyExcel.read(file.getInputStream(), Student.class, new StudentListener(studentService)).sheet().doRead(); return "导入成功"; } } ``` 4. 在上面的代码中,我们使用了 EasyExcel 提供的 read 方法,将 Excel 文件转换为 Student 类型的数据。同时,我们还定义了一个 StudentListener 类,用于处理读取到的每一行数据。代码如下: ```java public class StudentListener extends AnalysisEventListener<Student> { private List<Student> list = new ArrayList<>(); private StudentService studentService; public StudentListener(StudentService studentService) { this.studentService = studentService; } @Override public void invoke(Student student, AnalysisContext analysisContext) { list.add(student); } @Override public void doAfterAllAnalysed(AnalysisContext analysisContext) { studentService.saveBatch(list); } } ``` 5. 最后,我们需要在 StudentService 类中添加一个 saveBatch 方法,用于批量插入数据。代码如下: ```java @Service public class StudentService extends ServiceImpl<StudentMapper, Student> { public void saveBatch(List<Student> students) { saveBatch(students, 100); } } ``` 这样,我们就完成了使用 SpringBoot+Mybatis-plus+easyExcel 实现批量导入 Excel数据库的功能。当然,还有很多细节需要处理,比如 Excel 中的日期等格式问题,你可以根据实际需求进行适当的修改和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值