excel动态导入mysql_excel动态导入数据库---mysql

环境:

jdk1.8+poi-3.17+mysql-5.6+excel2010(xlsx)

工具类:

1.excel解析工具类,使用poi sax模式解析excel。生成数据格式为List>

private List> results=new ArrayList<>();

public void process(LinkedHashMap dataMap, int curRow) {

if(headerMap.isEmpty()){

for(Map.Entry e: dataMap.entrySet()){

if(null != e.getKey() && null != e.getValue()){

headerMap.put(e.getKey(), e.getValue().toLowerCase());

}

}

}else{

LinkedHashMap data = new LinkedHashMap<>();

for (Map.Entry e : headerMap.entrySet()) {

String key = e.getValue();

String value = null==dataMap.get(e.getKey())?"":dataMap.get(e.getKey());

data.put(key, value);

}

count.getAndIncrement();

results.add(data);

}

}

2.数据库的excel的配置信息t_fields--可以配置多个excel

fname--excel标题字段

fcode--标题字段对应的数据库字段

data_type--建表字段信息

ftable--excel对应的数据表

380036fa51e7af980fe1b8828478d27f.png

3.excel配置表实体类---jpa

package com.fdrx.model;

import lombok.Data;

import javax.persistence.*;

import java.io.Serializable;

/**

* Created by shea on 2019-06-05.

*/

@Data

@Entity

@Table(name ="t_fields")

public class ExcelBean implements Serializable {

@Id

@GeneratedValue(strategy= GenerationType.IDENTITY)

private Integer id;

@Column(length = 10)

private String fcode;

@Column(length = 10)

private String fname;

@Column(length = 20)

private String dataType;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值