Javaexcel数据导入mysql的实现示例详解

目录

一.新建Excel表并插入测试所需数据

二.新建springBoot工程

pom.xml

application.properties

三.创建实体类进行关系的映射

springBoot实现Excel数据导入到mysql数据库

一.新建Excel表并插入测试所需数据

二.新建springBoot工程

修改pom.xml文件以及application.properties。

pom.xml <!--缺少此jar包,导致@Mapper注解无效--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.1</version> </dependency> <!--java对象状态自动映射到关系数据库中数据上--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>5.0.2.RELEASE</version> </dependency> <!--实现类与xml之间的相互转换--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-oxm</artifactId> <version>5.0.2.RELEASE</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>5.2.12.Final</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-jpamodelgen</artifactId> <version>5.2.12.Final</version> </dependency> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-jpa</artifactId> <version>2.2.3.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.12</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.17</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.17</version> </dependency> application.properties

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.username=root 
spring.datasource.password=12345678
spring.datasource.url=jdbc:mysql://localhost:3306/excel?useUnicode=true&useSSL=false&characterEncoding=UTF-8&serverTimezone=UTC
#配置通过jpa自动创建表
spring.jpa.hibernate.ddl-auto=create
#打印SQL
spring.jpa.show-sql=true

三.创建实体类进行关系的映射

启动项目就会在数据库自动创建实体类的表,创建完之后会仔细发现数据库里的字段和实体类里的字段顺序是不一样,会出现乱序状态,这是因为hibernate源码中用的是TreeMap存储实体类字段,TreeMap属性是无序的。具体的解决办法如下:

1.找到源码文件

2.在当前项目中创建一个和源码类一样的包结构和一样名字的类,直接复制源码文件所有代码到新建的类中。

3.将上图标识的TreeMap 修改为LinkedHashMap修改好之后重新启动项目,会发现实体类和数据库表中顺序对齐了。

4.Excel的DAO类接口,与Excel有关的持久化操作方法。

5.创建service层接口,与Excel有关的业务逻辑方法。

6.service层方法的实现,与用户信息有关的业务逻辑方法。详细代码如下:

package com.wxy.excel.service; import com.wxy.excel.mapper.ExcelRepository; import com.wxy.excel.entity.Excel; import com.wxy.excel.mapper.UserMapper; import org.apache.poi.hssf.usermodel.*; import org.apache.poi.ss.usermodel.*; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.web.multipart.MultipartFile; import org.apache.poi.hssf.usermodel.HSSFCellStyle; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.OutputStream; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; @Service public class ExcelServiceImpl implements ExcelService{ @Autowired private ExcelRepository excelRepository; @Autowired private UserMapper userMapper; @Override public boolean getExcel(MultipartFile file) throws Exception { List<Excel> list = new ArrayList<Excel>(); //1.得到上传的表 Workbook workbook2 = WorkbookFactory.create(file.getInputStream()); //2.获取test工作表 注意test就是excel下面的sheet名称 Sheet sheet2 = workbook2.getSheet("test"); //3.获取表的总行数 int num = sheet2.getLastRowNum(); //4.获取表总列数 int col = sheet2.getRow(0).getLastCellNum(); //5.遍历excel每一行 for (int j = 0; j <num; j++) { Row row1 = sheet2.getRow(j); // 如果单元格中有数字或者其他格式的数据,则调用setCellType()转换为string类型 Cell cell1 = row1.getCell(0); cell1.setCellType(CellType.STRING); //获取表中第i行,第2列的单元格 Cell cell2 = row1.getCell(1); cell2.setCellType(CellType.STRING); //获取excel表的第i行,第3列的单元格 Cell cell3 = row1.getCell(2); cell3.setCellType(CellType.STRING); Cell cell4 = row1.getCell(3); cell4.setCellType(CellType.STRING); Cell cell5 = row1.getCell(4); cell5.setCellType(CellType.STRING); //这里new 一个对象,用来装填从页面上传的Excel数据,字段根据上传的excel决定 Excel excel= new Excel(); excel.setId(cell1.getStringCellValue()); excel.setUsername(cell2.getStringCellValue()); excel.setEmail(cell3.getStringCellValue()); excel.setPassword(cell4.getStringCellValue()); excel.setRole(cell5.getStringCellValue()); list.add(excel); System.out.println("excel"+excel); } excelRepository.saveAll(list); return true; } @Override public void exportExcel(HttpServletResponse response) throws IOException { // 第一步,创建一个webbook,对应一个Excel文件 HSSFWorkbook wb = new HSSFWorkbook(); // 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet HSSFSheet sheet = wb.createSheet("test"); // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short HSSFRow row = sheet.createRow(0); // 第四步,创建单元格,并设置值表头 设置表头居中 HSSFCellStyle style = wb.createCellStyle(); // 创建一个居中格式 style.setAlignment(HorizontalAlignment.CENTER); /*此处根据情况自己自定义样式*/ HSSFCell cell = row.createCell(0); cell.setCellValue("ID"); cell.setCellStyle(style); cell = row.createCell(1); cell.setCellValue("姓名"); cell.setCellStyle(style); cell = row.createCell(2); cell.setCellValue("邮箱"); cell.setCellStyle(style); cell = row.createCell(3); cell.setCellValue("密码"); cell.setCellStyle(style); cell = row.createCell(4); cell.setCellValue("角色"); cell.setCellStyle(style); // 第五步,写入实体数据 实际应用中这些数据从数据库得到, List<Excel> list = userMapper.getAllUser(); for (int i = 0; i < list.size(); i++) { row = sheet.createRow(i + 1); Excel excel = list.get(i); // 创建单元格,并设置值 row.createCell(0).setCellValue(excel.getId()); row.createCell(1).setCellValue(excel.getUsername()); row.createCell(2).setCellValue(excel.getEmail()); row.createCell(3).setCellValue(excel.getPassword()); row.createCell(4).setCellValue(excel.getRole()); } //第六步,输出Excel文件 OutputStream output = response.getOutputStream(); response.reset(); //设置日期格式 SimpleDateFormat df = new SimpleDateFormat("yyyyMMddHHmmss"); // 获取当前系统时间 String fileName = df.format(new Date()); //设置导出文件表头(即文件名) response.setHeader("Content-disposition", "attachment; filename=" + fileName + ".xls"); //设置返回内容类型 response.setContentType("application/msexcel"); wb.write(output); output.close(); } }

7.Controller层实现。

8.前端html实现.

9.最终把excel数据导入到mysql数据库的效果如下:

到此这篇关于Java excel数据导入mysql的实现示例详解的文章就介绍到这了,更多相关Java excel内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    mac怎么安装mysql| macbook怎么下载mysql

    mac怎么安装mysql| macbook怎么下载mysql,标签,学习python 不得不学习的就是数据库,那么在开始学习数据库之前,那么今天我们先说下怎么安装m

    MySQL更新更新页面1/4。

    MySQL更新更新页面1/4。,,插入和替换 插入和替换语句的功能是将新数据插入表中,这两个语句的语法相似,它们之间的主要区别是如何处理重复的

    mysql数据库启动失败

    mysql数据库启动失败,报错,非正常,1、原因 公司服务器故障,非正常停机导致数据库启动失败。 报错信息 [ [email protected] dmp]# /etc/ini

    mysql长整型是什么

    mysql长整型是什么,整型,数据类型,语法,用户,填充,版本,MySQL长整型是“BIGINT”,是MySQL中最常用的数据类型之一,其可以用来存储较大的整数值,与

    深入理解MySQL分区

    深入理解MySQL分区,查询,数据,列表,索引,操作,按键,MySQL数据库是一个开源的关系型数据库管理系统。在一些大型数据环境中,为了更好地管理数据、

    mysql 如何查询

    mysql 如何查询,查询,数据,语句,条件,选取,排序,MySQL是一款常用的关系型数据库管理系统,被广泛应用于各种网站和应用开发。在MySQL中查询数据是

    MySQL中怎么实现分页操作

    MySQL中怎么实现分页操作,数据,显示,偏移量,分页,查询,初始,一、 背景什么是分页,就是查询时候数据量太大,一次性返回所有查询结果既耗费网络资源

    mysql怎么连接数据库

    mysql怎么连接数据库,服务,启动,数据库,命令,登录,步骤,mysql连接数据库的方法:1、通过计算机管理方式或通过命令行方式执行“net start mysql”

    mysql 查询拼接

    mysql 查询拼接,函数,字段,字符串,查询,分隔符,连接,MySQL 查询拼接在使用 MySQL 进行查询时,有时需要将多个字段或多张表中的字段进行拼接,这时

    怎么启动 mysql

    怎么启动 mysql,启动,服务器,输入,命令提示符,终端,命令,MySQL是一种广泛使用的关系型数据库管理系统。它是一种可扩展性强、性能卓越、跨平台