大数据量excel导入mysql_十万级百万级数据量的Excel文件导入并写入数据库

本文探讨了在处理十万级至百万级数据量的Excel文件导入MySQL的需求,重点在于解决数据写入数据库的效率问题。通过采用多线程的方式,每次处理2000条数据,利用线程池并发写入,显著提升了导入速度。同时,文章介绍了使用Springboot、POI库和PGSQL实现的代码示例,展示了如何通过线程同步确保数据导入的完整性和一致性。
摘要由CSDN通过智能技术生成

一.需求分析

最近接到一个需求,导入十万级,甚至可能百万数据量的记录了车辆黑名单的Excel文件,借此机会分析下编码过程;

首先将这个需求拆解,发现有三个比较复杂的问题:

问题一:Excel文件导入后首先要被解析为存放对象的列表,数据量大的情况下可能会导致内存溢出,解析时间过长;

问题二:插入数据库的时候,数据量大,写入的时间长

问题三:要对数据库中的现有数据进项判断,不仅仅要做插入动作,还要将数据库的数据与导入的数据对比,判断是否做更新操作

其中:

问题一和问题三,可以看做同一类,因为主要涉及内存计算导致的性能问题,以及内存占用过大的溢出问题,

关于这两个问题,现在线上的机器基本上是4核8G的配置集群部署,内存并不是关键,我会在另一篇文章中给出我的方案,

今天主要针对问题二,写入的数据库的问题给出我的方案,

问题二主要是多次写入数据库的问题,显然,如果有几十万条数据,那么是不可能连续写几十万次的,不然要写到后年马月才能全部入库,

解决方案:

这里我主要采用了多线程的写入方式,十万条数据,2000条写一次(可以自己定义),用线程池提交多个线程任务同时写入,提高性能

二.代码环境

Springboot2.1.3+POI+PGSQL

controller层代码

@PostMapping("/upload")public void upload1(MultipartFile file, @Validated UploadReq req) throwsException {//从数据库查询出现有的数据,根据去重的字段分组去构建成一个HashMap,通过containsKey()判断//将需要更新的数据放到updateList中

List updateList=new ArrayList<>();//已取值的行数

int

要实现这个功能,你需要进行以下步骤: 1. 在Winform窗体中添加一个“打开文件”按钮,让用户可以选择要导入Excel文件。 2. 使用C#的Excel Interop库或第三方库,读取Excel文件中的数据。如果数据量很大,可以考虑使用分页读取的方式,避免内存溢出。 3. 将读取到的数据存储在内存中,可以使用List、DataTable等数据结构。 4. 使用C#的MySQL Connector库连接到MySQL数据库,将数据写入数据库中。同样需要考虑性能问题,可以使用事务等方式提高写入效率。 下面是一个简单的示例代码,供参考: ```csharp using System; using System.Collections.Generic; using System.Data; using System.Windows.Forms; using MySql.Data.MySqlClient; using Excel = Microsoft.Office.Interop.Excel; namespace ExcelToMySQL { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void btnOpen_Click(object sender, EventArgs e) { // 打开Excel文件 OpenFileDialog openFileDialog = new OpenFileDialog(); openFileDialog.Filter = "Excel文件|*.xlsx;*.xls"; if (openFileDialog.ShowDialog() == DialogResult.OK) { // 读取Excel文件中的数据 Excel.Application excel = new Excel.Application(); Excel.Workbook workbook = excel.Workbooks.Open(openFileDialog.FileName); Excel.Worksheet worksheet = workbook.Sheets[1]; Excel.Range range = worksheet.UsedRange; List<string[]> dataList = new List<string[]>(); for (int i = 2; i <= range.Rows.Count; i++) { string[] data = new string[range.Columns.Count]; for (int j = 1; j <= range.Columns.Count; j++) { data[j - 1] = range.Cells[i, j].Value.ToString(); } dataList.Add(data); } workbook.Close(); excel.Quit(); // 将数据写入MySQL数据库 string connStr = "server=localhost;user=root;database=test;password=123456;"; MySqlConnection conn = new MySqlConnection(connStr); conn.Open(); MySqlTransaction transaction = conn.BeginTransaction(); try { foreach (string[] data in dataList) { string sql = "INSERT INTO table_name (column1, column2, column3) VALUES (@value1, @value2, @value3)"; MySqlCommand command = new MySqlCommand(sql, conn, transaction); command.Parameters.AddWithValue("@value1", data[0]); command.Parameters.AddWithValue("@value2", data[1]); command.Parameters.AddWithValue("@value3", data[2]); command.ExecuteNonQuery(); } transaction.Commit(); MessageBox.Show("导入成功!"); } catch (Exception ex) { transaction.Rollback(); MessageBox.Show("导入失败:" + ex.Message); } conn.Close(); } } } } ``` 在上面的示例代码中,需要将“table_name”和“column1/2/3”替换成实际的表名和列名。此外,还需要将“server”、“user”、“database”和“password”替换成实际的MySQL连接信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值