融资项目——EasyExcel将Excel文件保存至数据库

        上一篇博客已经基本介绍了EasyExcel的配置与基本使用方法。现在准备使用EasyExcel将Excel文件保存至数据库。

1.由于我们想每读取Excel中的N条记录后将这些记录全部写入数据库中。所以首先我们在Mybatis文件内先要写一个批量保存Excel文件中的记录的sql语句。

    <insert id="insertBatch">
        insert into dict (
        id ,
        parent_id ,
        name ,
        value ,
        dict_code
        ) values
        <foreach collection="list" item="item" index="index" separator=",">
            (
            #{item.id} ,
            #{item.parentId} ,
            #{item.name} ,
            #{item.value} ,
            #{item.dictCode}
            )
        </foreach>
    </insert>

随后在Mapper接口中定义insertBatch方法。

public interface DictMapper extends BaseMapper<Dict> {

    void insertBatch(List<ExcelDictDTO> list);

}

2. 首先创建相应的实体类(对应Excel表中一个记录)的监听器。

@Slf4j
public class ExcelDictDTOListener extends AnalysisEventListener<ExcelDictDTO> {
    private List<ExcelDictDTO> excelDictDTOList=new ArrayList<>();

    private static final int BATCH_COUNT=10;
    private DictMapper dictMapper;
    //传入mapper对象
    public ExcelDictDTOListener(DictMapper dictMapper) {
        this.dictMapper = dictMapper;
    }

    @Override
    public void invoke(ExcelDictDTO excelDictDTO, AnalysisContext analysisContext) {
        log.info("data:{}",excelDictDTO);
        excelDictDTOList.add(excelDictDTO);
        if(excelDictDTOList.size()>=BATCH_COUNT){
            saveData();
            excelDictDTOList.clear();
        }
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        // 不足BATCH_COUNT数的记录在这里存储
        if(excelDictDTOList.size()>0)saveData();
        log.info("所有数据解析完成!");
    }
    private void saveData() {
        log.info("{}条数据,开始存储数据库!", excelDictDTOList.size());
        // 批量插入
        dictMapper.insertBatch(excelDictDTOList);
        log.info("存储数据库成功!");
    }
}

3.创建相关的服务类,读取Excel数据流的内容。

@Service
public class DictServiceImpl extends ServiceImpl<DictMapper, Dict> implements DictService {
    @Transactional
    @Override
    public void importDictDataByExcel(InputStream inputStream){
        EasyExcel.read(inputStream, ExcelDictDTO.class,new ExcelDictDTOListener(dictMapper)).sheet().doRead();
    }


}

4.创建相关Controller,通过getInputStream方法获取excel文件的数据流。

@Api("数据字典的管理")
@RestController
@RequestMapping("/admin/core/dict")
@Slf4j
@CrossOrigin
public class AdminDictController {
    @Autowired
    private DictService dictService;

    @ApiOperation("导入Excel表")
    @PostMapping("/import")
    public R importExcel(@RequestParam("file")MultipartFile file){
        try {
            InputStream inputStream=file.getInputStream();
            dictService.importDictDataByExcel(inputStream);
            return R.ok().message("导入成功");
        }catch (Exception e){
            throw new BusinessException(ResponseEnum.UPLOAD_ERROR,e);
        }

    }
}

在编写代码时,逻辑顺序为步骤1-2-3-4,但在实际调用时逻辑顺序为步骤4-3-2-1。

相关推荐

  1. 融资项目——EasyExcelExcel文件保存数据库

    2024-01-24 15:02:04       66 阅读
  2. 每个Excel文件数据量统一减少120000行

    2024-01-24 15:02:04       37 阅读
  3. 【springboot】【easyexcelexcel文件读取

    2024-01-24 15:02:04       60 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-24 15:02:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-24 15:02:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-24 15:02:04       82 阅读
  4. Python语言-面向对象

    2024-01-24 15:02:04       91 阅读

热门阅读

  1. 进制转换(C++)(简易)(字符串)

    2024-01-24 15:02:04       50 阅读
  2. 旅游MR混合现实情景实训教学系统教学

    2024-01-24 15:02:04       57 阅读
  3. Redis的持久化!!!

    2024-01-24 15:02:04       54 阅读
  4. Relay Arm® 计算库集成

    2024-01-24 15:02:04       48 阅读
  5. 【Qt+SQLite使用】

    2024-01-24 15:02:04       66 阅读
  6. leetcode - 527. Word Abbreviation

    2024-01-24 15:02:04       50 阅读
  7. Spring/Spring boot项目接入traceId

    2024-01-24 15:02:04       45 阅读
  8. C Primer Plus(第六版)13.11 编程练习 第11题

    2024-01-24 15:02:04       48 阅读