使用三级联动的形式将数据导入数据库,再用poi做导入导出操作的具体流程

本文介绍了使用JPA框架进行三级联动的数据导入数据库的详细流程,包括从Excel读取数据、Service层处理、Controller层控制以及配置和枚举相关设置。通过实例展示了如何将Excel数据导入数据库,并提供了进一步的导入地址。
摘要由CSDN通过智能技术生成

我想先说一下做这个的感受
1.我参与真正的项目开发(实习)还没两个月,内容都不知道(确实能力不够吧)
2.给我三天时间,说实话实际需求和网上的都不太一样(我都崩溃了)

不说废话了,开搞
这里只拿一小部分举例
接着上篇:https://blog.csdn.net/qq_40383839/article/details/99713825
想要表和库的可以私信我

框架JPA

1.先读取Eecel,在导入数据库

导入的excel
在这里插入图片描述
导入后的样子
在这里插入图片描述

2.Service层

 /**
     * 将所有sheet中的数据读出来;
     * 每一行数据是一个字符串数组
     */
    public static List<String[]> getData(String fileName,List<String[]> datas) throws ServiceException {
   
        File file = new File(Constants.getHomeDir(DirectoryEnum.update_excel)+"\\"+fileName);
        FileInputStream is = null;
        Workbook workbook = null;
        try {
   
            is = new FileInputStream(file);
            workbook = new HSSFWorkbook(is);
        } catch (FileNotFoundException e) {
   
            e.printStackTrace();
        } catch (IOException e) {
   
            e.printStackTrace();
        }
        try {
   
            if (workbook != null) {
   
                for (int sheetNum = 0; sheetNum < workbook.getNumberOfSheets(); sheetNum++) {
   

                    //获得当前sheet工作表
                    Sheet sheet = workbook.getSheetAt(sheetNum);
                    if (sheet == null) {
   
                        continue;
                    }
                    //获得当前sheet的开始行
                    int firstRowNum = sheet.getFirstRowNum();
                    //获得当前sheet的结束行
                    int lastRowNum = sheet.getLastRowNum();
                    //循环除了第一行的所有行
                    for (int rowNum = firstRowNum + 1; rowNum <= lastRowNum; rowNum++) {
   
                        //获得当前行
                        Row row = sheet.getRow(rowNum);
                        if (row == null) {
   
                            continue;
                        }
                        //获得当前行的开始列
                        int firstCellNum = row.getFirstCellNum();
                        //获得当前行的列数
  
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值