1. 引入poi的两个依赖

<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.15</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.15</version>
</dependency>

2. controller层

package com.cdqd.app.controllers;

import com.cdqd.app.common.JsonRet;
import com.cdqd.app.exception.BizException;
import com.cdqd.app.service.TranslateService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.MultipartRequest; import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.Objects; /**
* @description:
* @author: Rosa
* @create: 2018-12-24 10:06
**/
@RestController
@RequestMapping("translate")
public class TranslateController { @Autowired
private TranslateService translateService; @PostMapping("source/name")
public JsonRet translateSourceName(HttpServletRequest request) throws Exception{
MultipartRequest multipartHttpServletRequest = (MultipartRequest) request;
MultipartFile multipartFile = multipartHttpServletRequest.getFile("file"); //如果为空,抛出异常,此处为自定义异常,如有需要请改写
if (Objects.requireNonNull(multipartFile).isEmpty()){
throw new BizException(4001);
} //存储临时文件
String fileName = multipartFile.getOriginalFilename();
String prefix = fileName.substring(Objects.requireNonNull(fileName).lastIndexOf("."));
File file = File.createTempFile(System.currentTimeMillis() + "", prefix);
multipartFile.transferTo(file); //调用service对流进行具体操作
translateService.translateSourceDatabase(new FileInputStream(file));
return JsonRet.buildRet(0);//
}
}

3. service层(给自己回忆用的,针对性强,读者没有必要往下看了)

接口: TranslateService.java

package com.cdqd.app.service;

import java.io.InputStream;

public interface TranslateService {

    void translateSourceDatabase(InputStream inputStream);
}

实现文件: TranslateServiceImpl.java

package com.cdqd.app.service.impl;

import com.cdqd.app.common.StringUtil;
import com.cdqd.app.entity.DatabaseEntity;
import com.cdqd.app.entity.TableEntity;
import com.cdqd.app.exception.BizException;
import com.cdqd.app.mapper.ColumnMapper;
import com.cdqd.app.mapper.DatabaseMapper;
import com.cdqd.app.mapper.TableMapper;
import com.cdqd.app.model.Column;
import com.cdqd.app.model.Database;
import com.cdqd.app.model.Table;
import com.cdqd.app.service.TableService;
import com.cdqd.app.service.TranslateService;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* @description:
* @author: Rosa
* @create: 2018-12-24 10:04
**/
@Service
public class TranslateServiceImpl implements TranslateService { @Autowired
private DatabaseMapper databaseMapper; @Autowired
private TableMapper tableMapper; @Autowired
private ColumnMapper columnMapper; @Autowired
private TableService tableService; @Override
public void translateSourceDatabase(InputStream inputStream) {
Map<String, Map<String, TableEntity>> databaseMap = getTransMap(inputStream);
//遍历所有库
if (databaseMap != null) {
for (String databaseEnName : databaseMap.keySet()) {
Database database = new Database();
database.setDatabaseEnName(databaseEnName);
//如果库存在则开始遍历表
if (databaseMapper.selectOne(database) != null) {
Integer databaseId = databaseMapper.selectOne(database).getDatabaseId();
//MapKey("tableEnName")
Map<String, TableEntity> dbTableMap = tableService.getTableEntityMap(databaseId); //<表英文名, 表实体>
Map<String, TableEntity> excelTableMap = databaseMap.get(databaseEnName); //遍历数据库map的表实体
for (String dbTableEnName : dbTableMap.keySet()) {
TableEntity dbTableEntity = dbTableMap.get(dbTableEnName);
//如果excel数据中有这边的表
if (excelTableMap.containsKey(dbTableEnName)) {
TableEntity excelTableEntity = excelTableMap.get(dbTableEnName);
//源表表名翻译
if (!StringUtil.isEmpty(excelTableEntity.getTableCnName())) {
Table table = new Table();
table.setTableId(dbTableEntity.getTableId());
table.setTableCnName(excelTableEntity.getTableCnName());
tableMapper.updateByPrimaryKeySelective(table);
}
//如果列不为空的话
if (dbTableEntity.getColumnList() != null && excelTableEntity.getColumnMap() != null) {
//<列英文名, 列实体>
Map<String, Column> excelColumnMap = excelTableEntity.getColumnMap();
for (Column dbColumn : dbTableEntity.getColumnList()) {
if (excelColumnMap.containsKey(dbColumn.getColumnEnName())) {
String columnCnName = excelColumnMap.get(dbColumn.getColumnEnName()).getColumnCnName();
if (!StringUtil.isEmpty(columnCnName)) {
//如果列中文名不为空,翻译列名
Column column = new Column();
column.setColumnId(dbColumn.getColumnId());
column.setColumnCnName(columnCnName);
columnMapper.updateByPrimaryKeySelective(column);
} }
}
}
}
}
}
}
}
// return TRANS_MAP;
} private Map<String, Map<String, TableEntity>> getTransMap(InputStream inputStream) {
Map<String, Map<String, TableEntity>> databaseMap = new HashMap<>();
try {
XSSFWorkbook workbook = new XSSFWorkbook(inputStream);
XSSFSheet sheet = workbook.getSheetAt(0);
for (int row = 1; row < sheet.getLastRowNum(); row++) {
XSSFRow xssfRow = sheet.getRow(row);
if (xssfRow.getCell(0) == null) {
continue;
}
String databaseName = String.valueOf(xssfRow.getCell(0));
String tableEnName = String.valueOf(xssfRow.getCell(1));
String tableCnName = String.valueOf(xssfRow.getCell(2));
String columnEnName = String.valueOf(xssfRow.getCell(3));
String columnCnName = String.valueOf(xssfRow.getCell(4)); Column column = new Column();
column.setColumnEnName(columnEnName);
column.setColumnCnName(columnCnName); if (tableEnName == null) {
continue;
}
if (databaseMap.containsKey(databaseName)) { //<表英文名, 表实体>
Map<String, TableEntity> excelTableMap = databaseMap.get(databaseName);
//如果表存在,获取那个表实体
if (excelTableMap.containsKey(tableEnName)) {
TableEntity excelTableEntity = excelTableMap.get(tableEnName); if (columnEnName != null && !columnEnName.equals("")) {
if (excelTableEntity.getColumnMap() != null) {
Map<String, Column> columnMap = excelTableEntity.getColumnMap();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
} else {
Map<String, Column> columnMap = new HashMap<>();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
}
}
excelTableMap.put(tableEnName, excelTableEntity);
} else {
//表不存在时插入表
TableEntity excelTableEntity = new TableEntity();
excelTableEntity.setTableEnName(tableEnName);
excelTableEntity.setTableCnName(tableCnName);
if (columnEnName != null && !columnEnName.equals("")) {
Map<String, Column> columnMap = new HashMap<>();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
}
excelTableMap.put(tableEnName, excelTableEntity);
}
} else {
Map<String, TableEntity> excelTableMap = new HashMap<>();
TableEntity excelTableEntity = new TableEntity();
excelTableEntity.setTableEnName(tableEnName);
excelTableEntity.setTableCnName(tableCnName);
if (columnEnName != null && !columnEnName.equals("")) {
Map<String, Column> columnMap = new HashMap<>();
columnMap.put(columnEnName, column);
excelTableEntity.setColumnMap(columnMap);
}
excelTableMap.put(tableEnName, excelTableEntity);
databaseMap.put(databaseName, excelTableMap);
}
}
return databaseMap;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}

spring boot缓存excel临时文件后再操作的更多相关文章

  1. Spring Boot项目指定启动后执行的操作

    Spring Boot项目指定启动后执行的操作: (1)实现CommandLineRunner 接口 (2)重写run方法 (3)声明执行顺序@Order(1),数值越小,优先级越高 (4)如果需要注 ...

  2. Spring boot缓存初体验

    spring boot缓存初体验 1.项目搭建 使用MySQL作为数据库,spring boot集成mybatis来操作数据库,所以在使用springboot的cache组件时,需要先搭建一个简单的s ...

  3. 3步轻松搞定Spring Boot缓存

    作者:谭朝红 前言 本次内容主要介绍基于Ehcache 3.0来快速实现Spring Boot应用程序的数据缓存功能.在Spring Boot应用程序中,我们可以通过Spring Caching来快速 ...

  4. 如何解决spring boot 项目导入依赖后代码报错问题

    如何解决spring boot 项目导入依赖后代码报错问题 2020-08-15  14:17:18 代码截图如图所示(由于本人问题已经解决,没来得及截图,所以在网上找了一张图片)

  5. Spring boot配置多个Redis数据源操作实例

    原文:https://www.jianshu.com/p/c79b65b253fa Spring boot配置多个Redis数据源操作实例 在SpringBoot是项目中整合了两个Redis的操作实例 ...

  6. Spring Boot 导出Excel表格

    Spring Boot 导出Excel表格 添加支持 <!--添加导入/出表格依赖--> <dependency> <groupId>org.apache.poi& ...

  7. Spring Boot缓存Ehcache

    Spring Boot 整合 Ehcache   修改 pom 文件 <!-- Spring Boot 缓存支持启动器 --> <dependency> <groupId ...

  8. spring boot, 容器启动后执行某操作

    常有在spring容器启动后执行某些操作的需求,现做了一个demo的实现,做一下记录,也希望可以给需要的同学提供参考. 1.spring启动后,以新线程执行后续需要的操作,所以执行类实现Runnabl ...

  9. Spring boot 配置 Tomcat 临时文件缓存目录

    1. 问题现象 spring boot 项目中,Tomcat 接收到 content-type 为 multipart/form-data 的请求时,需要将接收的文件缓存到临时目录(默认下载 /tmp ...

随机推荐

  1. LeetCode 669. Trim a Binary Search Tree修剪二叉搜索树 (C++)

    题目: Given a binary search tree and the lowest and highest boundaries as L and R, trim the tree so th ...

  2. Hbase多条件查询数据(FilterList)

    利用Filter进行筛选:HBase的Scan可以通过setFilter方法添加过滤器(Filter),这也是分页.多条件查询的基础.HBase为筛选数据提供了一组过滤器,通过这个过滤器可以在HBas ...

  3. Ztree + bootstarp-table 使用

    Ztree + bootstarp-table  使用 一. Ztree 1.引入js/css文件  Ztree官网 <!--ztree--> <link rel="sty ...

  4. centos 修改语言、时区

    修改时区 cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime hwclock -w 修改语言 查看当前语言:echo $LANG vim etc/l ...

  5. 重启服务器后Docker容器暴露的端口外网突然访问不了!!

    *:first-child { margin-top: 0 !important; } .markdown-body>*:last-child { margin-bottom: 0 !impor ...

  6. 第21课 shared_ptr共享型智能指针

    一. shared_ptr的基本用法 (一)与unique_ptr的比较 比较 shared_ptr unique_ptr 备注 初始化 ①shared_ptr<T> sp; sp.res ...

  7. Debian kvm网络配置

    安装brctl apt-get install bridge-utils 设置网桥 可编辑 /etc/network/interface 文件.不过,我建议在 /etc/network/interfa ...

  8. Kafka producer异步发送在某些情况会阻塞主线程,使用时候慎重

    最近发现一个Kafka producer异步发送在某些情况会阻塞主线程,后来在排查解决问题过程中发现这可以算是Kafka的一个说明不恰当的地方. 问题说明 在很多场景下我们会使用异步方式来发送Kafk ...

  9. .NET CORE 控制台应用程序配置log4net日志文件

    使用文件格式记录日志 1.新建一个.NET CORE控制台应用程序,添加log4net.dll引用,打开工具->NuGet包管理器->管理解决方案的NuGet程序包. 2.在NuGet-解 ...

  10. ADO.NET中使用事务

    using (SqlConnection conn = new SqlConnection(k2ConnStr)) { SqlCommand cmd = new SqlCommand(sql, con ...