Excel与MySQL数据库的导入与导出
应用场景
在许多时候,我们希望数据能够很好地在各个系统之间转移,同时便于非专业人员阅读,如果程序员一点点打字导出的话,不知道要打到什么时候,于是我们便采用日常工作中常用的Excel表格来作为媒介,将数据导入MySQL或将数据导出至Excel。
选择jar包
jxl && POI
jxl是一个开源的Java Excel API项目,通过Jxl,Java可以很方便的操作微软的Excel文档。除了Jxl之
外,还有Apache的一个POI项目,也可以操作Excel,两者相比之下:Jxl使用方便,但功能相对POI比较
弱,很多时候,一个软件应用程序需要生成Microsoft Excel文件格式的报告。有时,一个应用程序甚至希
望将Excel文件作为输入数据。例如,一个公司开发的应用程序将财务部门需要所有输出生成自己的
Excel。
Apache POI是一种流行的API,它允许程序员使用Java程序创建,修改和显示MS Office文件。这由
Apache软件基金会开发使用Java分布式设计或修改Microsoft Office文件的开源库。它包含类和方法对
用户输入数据或文件到MS Office文档进行解码。
使用jxl包导入导出
首先添加依赖
<dependency>
<groupId>net.sourceforge.jexcelapi</groupId>
<artifactId>jxl</artifactId>
<version>2.6.12</version>
</dependency>
将MySQL数据导出
在jsp中创建一个按钮
Controller层
@Autowired
@Qualifier("BookServiceImpl")
private BookService bookService;
//==========导出Excel===========
@RequestMapping("/underwrite_export")
@ResponseBody
public void exportFile(HttpServletResponse response) throws Exception {
// 1.文件下载响应头
response.setHeader("Content-Disposition", "attachment;filename=underwrite.xls");
// 2.响应到浏览器
WritableWorkbook workbook = Workbook.createWorkbook(response.getOutputStream());
// 创建工作簿sheet
WritableSheet sheet = workbook.createSheet("underwrite", 0);
// 3.设置column名
sheet.addCell(new Label(0, 0, "书籍号"));
sheet.addCell(new Label(1, 0, "书籍名称"));
sheet.addCell(new Label(2, 0, "书籍数量"));
sheet.addCell(new Label(3, 0, "详情"));
// 4.把核保的数据填充到工作簿中 service调用selectExport()查询数据库
List<Books> list = bookService.queryAllBook();
System.out.println(list.toArray());
try{
for (int i = 0, j = 1; i < list.size(); i++, j++) {
// UnderwriteWait underwrite = list.get(i);
Books underwrite = list.get(i);
//System.out.println(underwrite);
//设置列宽
sheet.setColumnView(i, 16);
//重新设置部分列宽
sheet.setColumnView(3, 14);
sheet.setColumnView(6, 10);
sheet.setColumnView(7, 10);
//设置行高
sheet.setRowView(i, 350);
//设置字体的attribute
WritableFont font1=new WritableFont(WritableFont.createFont("楷体 _GB2312"), 12, WritableFont.NO_BOLD);
WritableCellFormat format1=new WritableCellFormat(font1);
System.out.println(underwrite.getBookID());
sheet.addCell(new Label(0, j, underwrite.getBookID()+"",format1));
sheet.addCell(new Label(1, j, underwrite.getBookName(),format1));
sheet.addCell(new Label(2, j, underwrite.getBookCounts()+"",format1));
sheet.addCell(new Label(3, j, underwrite.getDetail(),format1));
}}catch (Exception e){
e.printStackTrace();
}
// 5.写入数据
workbook.write();
// 6.关闭资源
workbook.close();
}
导入Excel至数据库
jsp中创建文件上传表单
Controller层
@RequestMapping("/underwrite_import")
public String importFile(MultipartFile file) throws Exception {
// 1.获取用户上传的文件
Workbook workbook = Workbook.getWorkbook(file.getInputStream());
// 2.获取工作簿sheet
Sheet sheet = workbook.getSheet(0);
// 3.获取总行数
int rows = sheet.getRows();
for (int i = 1; i < rows; i++) {
Books underwrite = new Books();
underwrite.setBookID(Integer.parseInt(sheet.getCell(0, i).getContents()));
underwrite.setBookName(sheet.getCell(1, i).getContents());
underwrite.setBookCounts(Integer.parseInt(sheet.getCell(2, i).getContents()));
underwrite.setDetail(sheet.getCell(3, i).getContents());
// 4.添加到数据库中
bookService.addBook(underwrite);
}
// 5.关闭资源
workbook.close();
return "redirect:/book/allBook";
}
注:不要忘记在dao.xml中添加文件传输类
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 请求的编码格式,必须和jSP的pageEncoding属性一致,以便正确读取表单的内容,默认为ISO-8859-1 -->
<property name="defaultEncoding" value="utf-8"/>
<!-- 上传文件大小上限,单位为字节(10485760=10M) -->
<property name="maxUploadSize" value="10485760"/>
<property name="maxInMemorySize" value="40960"/>
</bean>
Excel与MySQL数据库的导入与导出的更多相关文章
- 利用Java进行MySql数据库的导入和导出
利用Java来进行Mysql数据库的导入和导出的总体思想是通过Java来调用命令窗口执行相应的命令. MySql导出数据库的命令如下: mysqldump -uusername -ppassword ...
- MySQL数据库的导入和导出
1.导入数据库 在命令行下输入: mysql -u username -p test < /home/data/test.sql 说明: username 是 ...
- linux mysql 数据库操作导入导出 数据表导出导入
linux mysql 数据库操作导入导出 数据表导出导入 1,数据库导入 mysql -uroot -p show databases; create database newdb; use 数据库 ...
- 使用SQLyog对mysql数据库的数据结构进行导出、导入
主要分为两个步骤: 一.使用SQLyog对mysql数据库的数据结构进行导出 1.鼠标右键选择需要导出数据结构的数据库——>点击[备份/导出]——>点击[备份数据库,转储到SQL....] ...
- 从Mysql数据库中导入导出表结构
1.从Mysql数据库中导入sql表 很简单,只需要一个命令即可搞定:[root@localhost ~]# mysql -uroot -piweb_xxx_mysql iweb < modif ...
- MySQL数据库的导入方法
问题 如何导入MySQL数据库 解决方案 1. 概述MySQL数据库的导入,有两种方法:1) 先导出数据库SQL脚本,再导入:2) 直接拷贝数据库目录和文件. 在不同操作系统或MySQL版本情况下,直 ...
- python2.7爬取豆瓣电影top250并写入到TXT,Excel,MySQL数据库
python2.7爬取豆瓣电影top250并分别写入到TXT,Excel,MySQL数据库 1.任务 爬取豆瓣电影top250 以txt文件保存 以Excel文档保存 将数据录入数据库 2.分析 电影 ...
- Oracle数据库的导入和导出
Oracle数据库的导入和导出,是一项重要的的技术活,不但解决了数据库的导入导出,更方便快捷的获得数据. 使用imp和exp导入导出数据 使用exp导出数据 存放目录为\ORACLE_HOME\BIN ...
- mysql数据库的导入导出
当我们在操作数据库的时候,难免会遇到数据导入导出的一些操作,今天突然学到了这个知识点,特意来给大家分享. 我用的是data的这条数据 1.使用数据 mysql> use data; Databa ...
随机推荐
- 【LeetCode】653. Two Sum IV - Input is a BST 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 方法一:BFS 方法二:DFS 日期 题目地址:ht ...
- 【LeetCode】166. Fraction to Recurring Decimal 解题报告(Python)
[LeetCode]166. Fraction to Recurring Decimal 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingz ...
- Lucky Substrings
而在26以内且属于fibonacci数列的数为1,2,3,5,8,13,21时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 A string s is LUCKY if ...
- hdu 5592 ZYB's Premutation(线段树优化)
设f_ifi是第ii个前缀的逆序对数,p_ipi是第ii个位置上的数,则f_i-f_{i-1}fi−fi−1是ii前面比p_ipi大的数的个数.我们考虑倒着做,当我们处理 ...
- mybatis查询时使用基本数据类型接收报错-attempted to return null from a method with a primitive return type (int)
一.问题由来 自己在查看日志时发现日志中打印了一行错误信息为: 组装已经放养的宠物数据异常--->Mapper method 'applets.user.mapper.xxxMapper.xxx ...
- Are Loss Functions All the Same?
目录 概 主要内容 一些假设 损失函数 损失函数的统计性质 收敛速度 分类的界 Rosasco L, De Vito E, Caponnetto A, et al. Are loss function ...
- 云南农职《JavaScript交互式网页设计》 综合机试试卷⑥——简易旅游网
本页面分为顶部导航.登录注册栏,中部图片展示.主体内容和底部反馈模板 一.导航栏部分 要求一:设置菜单栏(二级菜单)和登录注册模块 要求二:当鼠标悬停到菜单栏(一级菜单)时,二级菜单以滑动效果滑出显示 ...
- Hadoop编译打包记录
Hadoop编译打包,基于2.7.2版本的源码. # 打包过程中需要使用到的工具 java -version mvn -version ant -version type protoc type cm ...
- Git 远程分支常用操作
# 查看远程仓库推拉地址,分支信息,分支跟踪情况等 git remote show origin # 拉取远程仓库的变更内容到本地 git fetch origin # 拉取并合并仓库的变更内容到本地 ...
- 《selenium2 python自动化测试》(高清).PDF,免费无需任何解压密码
链接:https://pan.baidu.com/s/1eAI0mXvJeblBn2Tn9WClEA 提取码:7m5u