excel 导入到mysql

本文介绍如何使用phpMyAdmin将CSV文件高效地导入到MySQL数据库中,包括数据格式转换及常见问题解决方法。
http://www.slyar.com/blog/phpmyadmin-csv-mysql.html
### 使用 C# 将 Excel 文件数据导入到 MySQL 数据库 为了实现这一目标,通常会采用 `Microsoft.Office.Interop.Excel` 库来处理 Excel 文件,并使用 `MySql.Data.MySqlClient` 来连接并操作 MySQL 数据库。下面是一个完整的示例代码片段展示如何完成此过程。 #### 准备工作 确保已经安装了必要的 NuGet 包: - MySql.Data 用于与 MySQL 数据库交互。 - Microsoft.Office.Interop.Excel 用来读取 Excel 文档中的数据。 可以通过 Visual Studio 的包管理器控制台执行如下命令来进行安装: ```shell Install-Package MySql.Data Install-Package Microsoft.Office.Interop.Excel ``` #### 示例代码 ```csharp using System; using System.Data; using Excel = Microsoft.Office.Interop.Excel; using MySql.Data.MySqlClient; public class ExcelToMySQLImporter { private string _excelFilePath; private string _connectionString; public ExcelToMySQLImporter(string excelFilePath, string connectionString) { _excelFilePath = excelFilePath; _connectionString = connectionString; } /// <summary> /// 导入Excel文件至指定的MySQL表内. /// </summary> public void Import() { var app = new Excel.Application(); Workbook workbook = null; Worksheet worksheet = null; try { // 打开Excel文档 workbook = app.Workbooks.Open(_excelFilePath); worksheet = (Worksheet)workbook.Sheets[1]; Range usedRange = worksheet.UsedRange; DataTable dt = ConvertRangeToDataTable(usedRange); using (var connection = new MySqlConnection(_connectionString)) { connection.Open(); foreach (DataRow row in dt.Rows) { InsertRowIntoDatabase(connection, row); } } } finally { if(worksheet != null) Marshal.ReleaseComObject(worksheet); if(workbook != null) { workbook.Close(false); Marshal.ReleaseComObject(workbook);} if(app != null) { app.Quit(); Marshal.ReleaseComObject(app);} } } private static DataTable ConvertRangeToDataTable(Range range) { int rowCount = range.Rows.Count; int colCount = range.Columns.Count; DataTable table = new DataTable(); for(int i = 1; i <= colCount; ++i){ table.Columns.Add(new DataColumn($"Column{i}")); } object[,] values = (object[,])range.Value[XlRangeValueDataType.xlRangeValueDefault]; for(int r = 1; r <= rowCount; ++r){ DataRow newRow = table.NewRow(); for(int c = 1; c <= colCount; ++c){ newRow[c - 1] = GetCellValue(values[r,c]); } table.Rows.Add(newRow); } return table; } private static object GetCellValue(object value) { if(value is DateTime dateTime && !dateTime.Equals(DateTime.MinValue)){ return dateTime.ToString("yyyy-MM-dd HH:mm:ss"); }else if(double.TryParse(value?.ToString(), out double numVal)){ return numVal; }else{ return value ?? DBNull.Value; } } private static void InsertRowIntoDatabase(MySqlConnection connection, DataRow dataRow) { MySqlCommand cmdInsert = new MySqlCommand( "INSERT INTO your_table_name_here VALUES (@col1,@col2,...)", connection ); // 添加参数化查询防止SQL注入攻击 AddParameters(cmdInsert, dataRow); cmdInsert.ExecuteNonQuery(); } private static void AddParameters(MySqlCommand command, DataRow dataRow) { for(int i = 0 ; i<dataRow.Table.Columns.Count;i++){ command.Parameters.AddWithValue("@col"+(i+1),dataRow[i]); } } } ``` 这段代码展示了如何打开一个 Excel 文件,将其内容转换成 `DataTable` 对象,再逐行插入到 MySQL 表中[^2]。注意,在实际应用时应替换 `"your_table_name_here"` 和相应的列名以匹配具体需求。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值