应用场景

在许多时候,我们希望数据能够很好地在各个系统之间转移,同时便于非专业人员阅读,如果程序员一点点打字导出的话,不知道要打到什么时候,于是我们便采用日常工作中常用的Excel表格来作为媒介,将数据导入MySQL或将数据导出至Excel。

选择jar包

  1. jxl && POI
  2. jxl是一个开源的Java Excel API项目,通过JxlJava可以很方便的操作微软的Excel文档。除了Jxl
  3. 外,还有Apache的一个POI项目,也可以操作Excel,两者相比之下:Jxl使用方便,但功能相对POI比较
  4. 弱,很多时候,一个软件应用程序需要生成Microsoft Excel文件格式的报告。有时,一个应用程序甚至希
  5. 望将Excel文件作为输入数据。例如,一个公司开发的应用程序将财务部门需要所有输出生成自己的
  6. Excel
  7. Apache POI是一种流行的API,它允许程序员使用Java程序创建,修改和显示MS Office文件。这由
  8. Apache软件基金会开发使用Java分布式设计或修改Microsoft Office文件的开源库。它包含类和方法对
  9. 用户输入数据或文件到MS Office文档进行解码。

使用jxl包导入导出

首先添加依赖

  1. <dependency>
  2. <groupId>net.sourceforge.jexcelapi</groupId>
  3. <artifactId>jxl</artifactId>
  4. <version>2.6.12</version>
  5. </dependency>

将MySQL数据导出

在jsp中创建一个按钮

Controller层

  1. @Autowired
  2. @Qualifier("BookServiceImpl")
  3. private BookService bookService;
  4. //==========导出Excel===========
  5. @RequestMapping("/underwrite_export")
  6. @ResponseBody
  7. public void exportFile(HttpServletResponse response) throws Exception {
  8. // 1.文件下载响应头
  9. response.setHeader("Content-Disposition", "attachment;filename=underwrite.xls");
  10. // 2.响应到浏览器
  11. WritableWorkbook workbook = Workbook.createWorkbook(response.getOutputStream());
  12. // 创建工作簿sheet
  13. WritableSheet sheet = workbook.createSheet("underwrite", 0);
  14. // 3.设置column名
  15. sheet.addCell(new Label(0, 0, "书籍号"));
  16. sheet.addCell(new Label(1, 0, "书籍名称"));
  17. sheet.addCell(new Label(2, 0, "书籍数量"));
  18. sheet.addCell(new Label(3, 0, "详情"));
  19. // 4.把核保的数据填充到工作簿中 service调用selectExport()查询数据库
  20. List<Books> list = bookService.queryAllBook();
  21. System.out.println(list.toArray());
  22. try{
  23. for (int i = 0, j = 1; i < list.size(); i++, j++) {
  24. // UnderwriteWait underwrite = list.get(i);
  25. Books underwrite = list.get(i);
  26. //System.out.println(underwrite);
  27. //设置列宽
  28. sheet.setColumnView(i, 16);
  29. //重新设置部分列宽
  30. sheet.setColumnView(3, 14);
  31. sheet.setColumnView(6, 10);
  32. sheet.setColumnView(7, 10);
  33. //设置行高
  34. sheet.setRowView(i, 350);
  35. //设置字体的attribute
  36. WritableFont font1=new WritableFont(WritableFont.createFont("楷体 _GB2312"), 12, WritableFont.NO_BOLD);
  37. WritableCellFormat format1=new WritableCellFormat(font1);
  38. System.out.println(underwrite.getBookID());
  39. sheet.addCell(new Label(0, j, underwrite.getBookID()+"",format1));
  40. sheet.addCell(new Label(1, j, underwrite.getBookName(),format1));
  41. sheet.addCell(new Label(2, j, underwrite.getBookCounts()+"",format1));
  42. sheet.addCell(new Label(3, j, underwrite.getDetail(),format1));
  43. }}catch (Exception e){
  44. e.printStackTrace();
  45. }
  46. // 5.写入数据
  47. workbook.write();
  48. // 6.关闭资源
  49. workbook.close();
  50. }

导入Excel至数据库

jsp中创建文件上传表单

Controller层

  1. @RequestMapping("/underwrite_import")
  2. public String importFile(MultipartFile file) throws Exception {
  3. // 1.获取用户上传的文件
  4. Workbook workbook = Workbook.getWorkbook(file.getInputStream());
  5. // 2.获取工作簿sheet
  6. Sheet sheet = workbook.getSheet(0);
  7. // 3.获取总行数
  8. int rows = sheet.getRows();
  9. for (int i = 1; i < rows; i++) {
  10. Books underwrite = new Books();
  11. underwrite.setBookID(Integer.parseInt(sheet.getCell(0, i).getContents()));
  12. underwrite.setBookName(sheet.getCell(1, i).getContents());
  13. underwrite.setBookCounts(Integer.parseInt(sheet.getCell(2, i).getContents()));
  14. underwrite.setDetail(sheet.getCell(3, i).getContents());
  15. // 4.添加到数据库中
  16. bookService.addBook(underwrite);
  17. }
  18. // 5.关闭资源
  19. workbook.close();
  20. return "redirect:/book/allBook";
  21. }

注:不要忘记在dao.xml中添加文件传输类

  1. <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  2. <!-- 请求的编码格式,必须和jSP的pageEncoding属性一致,以便正确读取表单的内容,默认为ISO-8859-1 -->
  3. <property name="defaultEncoding" value="utf-8"/>
  4. <!-- 上传文件大小上限,单位为字节(10485760=10M) -->
  5. <property name="maxUploadSize" value="10485760"/>
  6. <property name="maxInMemorySize" value="40960"/>
  7. </bean>

Excel与MySQL数据库的导入与导出的更多相关文章

  1. 利用Java进行MySql数据库的导入和导出

    利用Java来进行Mysql数据库的导入和导出的总体思想是通过Java来调用命令窗口执行相应的命令. MySql导出数据库的命令如下: mysqldump -uusername -ppassword  ...

  2. MySQL数据库的导入和导出

    1.导入数据库 在命令行下输入: mysql -u username -p test < /home/data/test.sql 说明: username                   是 ...

  3. linux mysql 数据库操作导入导出 数据表导出导入

    linux mysql 数据库操作导入导出 数据表导出导入 1,数据库导入 mysql -uroot -p show databases; create database newdb; use 数据库 ...

  4. 使用SQLyog对mysql数据库的数据结构进行导出、导入

    主要分为两个步骤: 一.使用SQLyog对mysql数据库的数据结构进行导出 1.鼠标右键选择需要导出数据结构的数据库——>点击[备份/导出]——>点击[备份数据库,转储到SQL....] ...

  5. 从Mysql数据库中导入导出表结构

    1.从Mysql数据库中导入sql表 很简单,只需要一个命令即可搞定:[root@localhost ~]# mysql -uroot -piweb_xxx_mysql iweb < modif ...

  6. MySQL数据库的导入方法

    问题 如何导入MySQL数据库 解决方案 1. 概述MySQL数据库的导入,有两种方法:1) 先导出数据库SQL脚本,再导入:2) 直接拷贝数据库目录和文件. 在不同操作系统或MySQL版本情况下,直 ...

  7. python2.7爬取豆瓣电影top250并写入到TXT,Excel,MySQL数据库

    python2.7爬取豆瓣电影top250并分别写入到TXT,Excel,MySQL数据库 1.任务 爬取豆瓣电影top250 以txt文件保存 以Excel文档保存 将数据录入数据库 2.分析 电影 ...

  8. Oracle数据库的导入和导出

    Oracle数据库的导入和导出,是一项重要的的技术活,不但解决了数据库的导入导出,更方便快捷的获得数据. 使用imp和exp导入导出数据 使用exp导出数据 存放目录为\ORACLE_HOME\BIN ...

  9. mysql数据库的导入导出

    当我们在操作数据库的时候,难免会遇到数据导入导出的一些操作,今天突然学到了这个知识点,特意来给大家分享. 我用的是data的这条数据 1.使用数据 mysql> use data; Databa ...

随机推荐

  1. Python obj与JSON相互转换

    1 # _*_ coding:utf-8 _*_ 2 3 def showJson(self, pipefd): 4 overdict = args.__dict__ 5 # 此时就可以用json.d ...

  2. Android NDK开发篇:Java与原生代码通信(原生方法声明与定义与数据类型)

    Java与原生代码通信涉及到原生方法声明与定义.数据类型.引用数据类型操作.NIO操作.访问域.异常处理.原生线程 1.原生方法声明与定义 关于原生方法的声明与定义在上一篇已经讲一点了,这次详细分析一 ...

  3. 【LeetCode】1046. Last Stone Weight 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 大根堆 日期 题目地址:https://leetco ...

  4. GCD (hdu 5726)

    GCD Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submis ...

  5. 1161 - Extreme GCD

    1161 - Extreme GCD    PDF (English) Statistics Forum Time Limit: 1 second(s) Memory Limit: 32 MB All ...

  6. Codeforces 777D:Cloud of Hashtags(暴力,水题)

    Vasya is an administrator of a public page of organization "Mouse and keyboard" and his ev ...

  7. KMM

    目录 概 主要内容 Huang J., Smola A., Gretton A., Borgwardt K. & Scholkopf B. Correcting Sample Selectio ...

  8. Stirling's Formula

    目录 Stirling's Formula Keith Conrad. Stirling's Formula. Stirling's Formula \[\lim_{n \rightarrow \in ...

  9. 「MySql高级查询与编程」练习:企业员工管理

    题目:企业员工管理 一.语言和环境 1.实现语言:SQL. 2.开发环境:MySQL,navicat for mysql. 二.题目(100分): 1.创建数据库及数据表: (1)创建数据库,名称为d ...

  10. 你在寻找Vue3移动端项目框架嘛?请看这里

    现在web开发变得更加美妙高效,在于开发工具设计得更好了,丰富性与易用性,都有所提高.丰富性带来了一个幸福的烦恼,就是针对实际应用场景,如何选择工具 ? 1. Vue Cli和Vite之间的选择 Vi ...