Java商品库存导入导出实现全解析
时间:2025-10-31 10:44:49 468浏览 收藏
本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《Java实现商品库存导入导出方法详解》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~
答案:基于Spring Boot和Apache POI实现商品库存的Excel导入导出。1. 添加Web、JPA、MySQL和POI依赖;2. 创建Product实体类映射数据库表;3. 使用XSSFWorkbook导出数据至Excel并设置响应头;4. 读取上传文件解析Excel内容并批量保存;5. 提供REST接口处理导出和导入请求,前端可触发下载或上传文件完成操作。

商品库存的导入导出功能在电商、仓储系统中非常常见。使用Java可以结合Spring Boot、Apache POI和数据库操作来高效实现Excel格式的导入导出。以下是具体实现思路和代码示例。
1. 准备工作:添加依赖
使用Maven管理项目依赖,在pom.xml中引入Spring Boot Web和Apache POI:
<font face="Courier New">
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>5.2.3</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies>
</font>
2. 定义商品实体类
创建一个Product实体,用于映射数据库表和Excel数据:
<font face="Courier New">
@Entity
@Table(name = "product")
public class Product {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
private Integer stock;
// 构造函数、getter 和 setter 省略
}
</font>
3. 实现Excel导出功能
使用XSSFWorkbook生成Excel文件,将数据库中的商品数据写入工作表:
<font face="Courier New">
@Service
public class ExportService {
@Autowired
private ProductRepository productRepository;
public void exportProductsToExcel(HttpServletResponse response) throws IOException {
List<Product> products = productRepository.findAll();
XSSFWorkbook workbook = new XSSFWorkbook();
XSSFSheet sheet = workbook.createSheet("商品库存");
// 创建表头
Row headerRow = sheet.createRow(0);
headerRow.createCell(0).setCellValue("ID");
headerRow.createCell(1).setCellValue("商品名称");
headerRow.createCell(2).setCellValue("库存数量");
// 填充数据
int rowNum = 1;
for (Product product : products) {
Row row = sheet.createRow(rowNum++);
row.createCell(0).setCellValue(product.getId());
row.createCell(1).setCellValue(product.getName());
row.createCell(2).setCellValue(product.getStock());
}
// 设置响应头
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
response.setHeader("Content-Disposition", "attachment; filename=products.xlsx");
workbook.write(response.getOutputStream());
workbook.close();
}
}
</font>
4. 实现Excel导入功能
读取上传的Excel文件,解析内容并批量保存到数据库:
<font face="Courier New">
@Service
public class ImportService {
@Autowired
private ProductRepository productRepository;
public void importProductsFromExcel(MultipartFile file) throws IOException {
XSSFWorkbook workbook = new XSSFWorkbook(file.getInputStream());
XSSFSheet sheet = workbook.getSheetAt(0);
List<Product> products = new ArrayList<>();
for (Row row : sheet) {
if (row.getRowNum() == 0) continue; // 跳过表头
Product product = new Product();
product.setName(row.getCell(1).getStringCellValue());
product.setStock((int) row.getCell(2).getNumericCellValue());
products.add(product);
}
productRepository.saveAll(products);
workbook.close();
}
}
</font>
5. 控制器层接口暴露
提供HTTP接口供前端调用:
<font face="Courier New">
@RestController
@RequestMapping("/api/products")
public class ProductController {
@Autowired
private ExportService exportService;
@Autowired
private ImportService importService;
@GetMapping("/export")
public void export(HttpServletResponse response) throws IOException {
exportService.exportProductsToExcel(response);
}
@PostMapping("/import")
public ResponseEntity<String> importFile(@RequestParam("file") MultipartFile file) {
try {
importService.importProductsFromExcel(file);
return ResponseEntity.ok("导入成功");
} catch (IOException e) {
return ResponseEntity.status(500).body("导入失败:" + e.getMessage());
}
}
}
</font>
前端可以通过表单上传Excel文件,或使用JavaScript触发下载。后端通过/api/products/export导出,通过/api/products/import导入。
基本上就这些。只要结构清晰,使用Spring Boot和POI处理Excel并不复杂,关键注意空值校验、异常处理和性能优化(如大数据量分批插入)。
今天关于《Java商品库存导入导出实现全解析》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
107 收藏
-
362 收藏
-
281 收藏
-
229 收藏
-
166 收藏
-
287 收藏
-
136 收藏
-
308 收藏
-
249 收藏
-
495 收藏
-
175 收藏
-
466 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习