Springboot上傳excel并將表格數(shù)據(jù)導入或更新mySql數(shù)據(jù)庫的過程
本文主要描述,Springboot-mybatis框架下上傳excel,并將之導入mysql數(shù)據(jù)庫的過程,如果用戶id已存在,則進行更新修改數(shù)據(jù)庫中該項信息,由于用到的是前后端分離技術,這里記錄的主要是后端java部分,通過與前端接口進行對接實現(xiàn)功能,使用layui等前端框架與之對接,也可以自己寫前端代碼,本文以Controller開始,從導入過程開始講述,其中包括字典表的轉換
1.在pom.xml文件中導入注解,主要利用POI
<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.9</version> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency>
2.Controller接口
@PostMapping("/save")
public String addUser(@RequestParam("file") MultipartFile file) {
String fileName = file.getOriginalFilename();
try {
return sysService.batchImport(fileName, file);
} catch (MyException e) {
e.printStackTrace();
return e.getMessage();
}catch(Exception e){
e.printStackTrace();
return "文件異常,導入失敗";
}
}
3.服務層接口
boolean import(String fileName, MultipartFile file) throws Exception;
4.業(yè)務層實現(xiàn)類
@Transactional(readOnly = false,rollbackFor = Exception.class)
@Override
public boolean import(String fileName, MultipartFile file) throws Exception {
Map<String, Integer> departmentMap = findDepartment();
Map<String, Integer> roleMap = findRole();
boolean notNull = false;
List<User> userList = new ArrayList<User>();
if (!fileName.matches("^.+\\.(?i)(xls)$") && !fileName.matches("^.+\\.(?i)(xlsx)$")) {
throw new MyException("上傳文件格式不正確");
}
boolean isExcel2003 = true;
if (fileName.matches("^.+\\.(?i)(xlsx)$")) {
isExcel2003 = false;
}
InputStream is = file.getInputStream();
Workbook wb = null;
if (isExcel2003) {
wb = new HSSFWorkbook(is);
} else {
wb = new XSSFWorkbook(is);
}
Sheet sheet = wb.getSheetAt(0);
if(sheet!=null){
notNull = true;
}
User user;
for (int r = 1; r <= sheet.getLastRowNum(); r++) {
Row row = sheet.getRow(r);
if (row == null){
continue;
}
user = new User();
if( row.getCell(0).getCellType() !=1){
throw new MyException("導入失敗(第"+(r+1)+"行,ID單元格格式請設為文本格式)");
}
String id = row.getCell(0).getStringCellValue();
if(id==null || id.isEmpty()){
throw new MyException("導入失敗(第"+(r+1)+"行,ID未填寫)");
}
String name = row.getCell(1).getStringCellValue();
if(name==null || name.isEmpty()){
throw new MyException("導入失敗(第"+(r+1)+"行,姓名未填寫)");
}
String department = row.getCell(2).getStringCellValue();
if(departmentMap.get(department)==null){
throw new MyException("導入失敗(第"+(r+1)+"行,不存在此單位或單位未填寫)");
}
String role = row.getCell(3).getStringCellValue();
if(roleMap.get(role)==null){
throw new MyException("導入失敗(第"+(r+1)+"行,不存在此角色或角色未填寫)");
}
Date date;
if(row.getCell(4).getCellType() !=0){
throw new MyException("導入失敗(第"+(r+1)+"行,入職日期格式不正確或未填寫)");
}else{
date = row.getCell(4).getDateCellValue();
}
user.setId(id);
user.setName(name);
user.setDepartmentId((int) departmentMap.get(department));
user.setRoleId((int) roleMap.get(role));
user.setDate(date);
userList.add(user);
}
for (User user : userList) {
String id = user.getId();
int cnt = userMapper.selectById(id);
if (cnt == 0) {
userMapper.addUser(user);
} else {
userMapper.updateUserById(user);
}
}
return notNull;
}
總結
以上所述是小編給大家介紹的Springboot上傳excel并將表格數(shù)據(jù)導入或更新mySql數(shù)據(jù)庫,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- 教你使用java將excel數(shù)據(jù)導入MySQL
- 如何將Excel文件導入MySQL數(shù)據(jù)庫
- php通過PHPExcel導入Excel表格到MySQL數(shù)據(jù)庫的簡單實例
- PHP上傳Excel文件導入數(shù)據(jù)到MySQL數(shù)據(jù)庫示例
- 使用phpexcel類實現(xiàn)excel導入mysql數(shù)據(jù)庫功能(實例代碼)
- php導入excel文件到mysql數(shù)據(jù)庫的方法
- phpMyAdmin下將Excel中的數(shù)據(jù)導入MySql的圖文方法
- Excel數(shù)據(jù)導入Mysql數(shù)據(jù)庫的實現(xiàn)代碼
- MySQL批量導入Excel數(shù)據(jù)(超詳細)
相關文章
Java使用Freemarker頁面靜態(tài)化生成的實現(xiàn)
這篇文章主要介紹了Java使用Freemarker頁面靜態(tài)化生成的實現(xiàn),頁面靜態(tài)化是將原來的動態(tài)網(wǎng)頁改為通過靜態(tài)化技術生成的靜態(tài)網(wǎng)頁,FreeMarker?是一個用?Java?語言編寫的模板引擎,它基于模板來生成文本輸,更多相關內容需要的小伙伴可以參考一下2022-06-06
SpringBoot集成echarts實現(xiàn)k線圖功能
ECharts是一款基于JavaScript的數(shù)據(jù)可視化圖表庫,提供直觀,生動,可交互,可個性化定制的數(shù)據(jù)可視化圖表,本文給大家介紹了SpringBoot集成echarts實現(xiàn)k線圖功能,文中有詳細的代碼示例供大家參考,需要的朋友可以參考下2024-07-07
如何使用MyBatis框架實現(xiàn)增刪改查(CRUD)操作
本文主要介紹了如何使用MyBatis框架實現(xiàn)增刪改查(CRUD)操作。首先介紹了MyBatis框架的基本概念和使用方法,然后分別介紹了如何使用MyBatis實現(xiàn)增刪改查操作。最后,通過一個簡單的示例演示了如何使用MyBatis框架實現(xiàn)CRUD操作。2023-05-05
Java?中導入excel時使用?trim()?無法去除空格的問題解決方案
這篇文章主要介紹了Java中導入excel時使用trim()無法去除空格的解決方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06
WMTS中TileMatrix與ScaleDenominator淺析
這篇文章主要為大家介紹了WMTS中TileMatrix與ScaleDenominator淺析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03

