C#通过ACE OLEDB驱动程序访问 Access和 Excel
ACE 代表 Access Connectivity Engine。它是 Microsoft 提供的一组组件,用于访问和操作 Microsoft Access 数据库以及其他类似的文件格式,如 Excel 工作簿。ACE 主要包括以下几部分:
-
ACE OLEDB 驱动程序:用于通过 OLE DB 提供程序访问 Access 数据库和 Excel 文件。例如,
Microsoft.ACE.OLEDB.12.0
是一个常见的提供程序版本,用于访问 Access 2007 及以上版本的数据库以及 Excel 2007 及以上版本的工作簿。 -
Access Database Engine:这是一个包含 ACE OLEDB 驱动程序的组件。它允许应用程序读取和写入 Access 数据库文件(
.accdb
或.mdb
文件)以及 Excel 文件(.xls
和.xlsx
文件)。 -
数据源提供程序:ACE 提供了支持 Access 数据库和 Excel 文件的 OLE DB 和 ODBC 数据源提供程序,允许使用标准的 SQL 查询来操作这些文件中的数据。
主要用途
- 数据库连接:ACE 允许应用程序连接到 Access 数据库文件(
.accdb
或.mdb
)并执行 SQL 查询。 - Excel 数据访问:ACE 允许应用程序通过 OLE DB 或 ODBC 读取和写入 Excel 工作簿中的数据。
安装和版本
ACE 数据库引擎的版本与 Microsoft Access 的版本相关。较新的版本(如 Microsoft.ACE.OLEDB.12.0
)支持较新的 Access 数据库格式和 Excel 文件格式。你可以从 Microsoft 的官方下载页面下载和安装适用于你系统的 Access Database Engine。
示例连接字符串
-
Access 数据库:
string connectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\path\to\your\database.accdb;";
-
Excel 文件:
string connectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\path\to\your\file.xlsx;Extended Properties='Excel 12.0 Xml;HDR=YES;'";
解释连接字符串参数
Provider=Microsoft.ACE.OLEDB.12.0
:指定使用 ACE 12.0 驱动程序。Data Source={filePath}
:指定 Excel 文件的路径。Extended Properties='Excel 12.0 Xml;HDR=YES;'
:Excel 12.0 Xml
:指定 Excel 文件的格式是 2007 或更高版本。HDR=YES
:指定第一行包含列头。
ACE 驱动程序是处理 Microsoft Access 和 Excel 文件数据的强大工具,广泛用于各种应用程序中以实现数据管理和分析功能。
确保表格名称和列名正确
- 检查 Excel 工作表名称:工作表的名称在 SQL 查询中要加上
$
符号,比如Sheet1$
。 - 检查列名:列名在 SQL 查询中必须与工作表中的列标题完全匹配,包括大小写和任何可能的额外空格。
using System;
using System.Data;
using System.Data.OleDb;
class xlsxOLEDBOleDbDataAdapter
{
static void Main()
{
// Excel 文件路径
string filePath = @"C:\Users\Administrator\Documents\Employees.xlsx";
string connectionString = $@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={filePath};Extended Properties='Excel 12.0 Xml;HDR=YES;'";
using (OleDbConnection connection = new OleDbConnection(connectionString))
{
connection.Open();
string query = "SELECT * FROM [Sheet1$]"; // 修改为实际的工作表名称
OleDbCommand command = new OleDbCommand(query, connection);
OleDbDataAdapter adapter = new OleDbDataAdapter(command);
DataTable dataTable = new DataTable();
adapter.Fill(dataTable);
foreach (DataRow row in dataTable.Rows)
{
foreach (var cell in row.ItemArray)
{
Console.Write(cell.ToString() + "\t");
}
Console.WriteLine();
}
}
Console.ReadKey();
}
}
using System;
using System.Data;
using System.Data.OleDb;
class xlsxOLEDBOleDbDataAdapter
{
static void Main()
{
// Excel 文件路径
string filePath = @"C:\Users\Administrator\Documents\Employees.xlsx";
string connectionString = $@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={filePath};Extended Properties='Excel 12.0 Xml;HDR=YES;'";
using (OleDbConnection connection = new OleDbConnection(connectionString))
{
connection.Open();
// 先检索表格结构,确保列名正确
string schemaQuery = "SELECT * FROM [Sheet1$] WHERE 1 = 0"; // 仅获取列名
OleDbCommand schemaCommand = new OleDbCommand(schemaQuery, connection);
OleDbDataAdapter schemaAdapter = new OleDbDataAdapter(schemaCommand);
DataTable schemaTable = new DataTable();
schemaAdapter.FillSchema(schemaTable, SchemaType.Source);
Console.WriteLine("列名列表:");
foreach (DataColumn column in schemaTable.Columns)
{
Console.WriteLine(column.ColumnName);
}
// 插入数据的 SQL 语句
string insertQuery = "INSERT INTO [Sheet1$] ([CustomerId], [CustomerName], [Email]) VALUES (?, ?, ?)";
// 创建命令对象
OleDbCommand command = new OleDbCommand(insertQuery, connection);
// 添加参数
command.Parameters.AddWithValue("?", "88881"); // CustomerId
command.Parameters.AddWithValue("?", "John Doe"); // CustomerName
command.Parameters.AddWithValue("?", "john.doe@example.com"); // Email
try
{
// 执行插入命令
int rowsAffected = command.ExecuteNonQuery();
Console.WriteLine($"{rowsAffected} rows inserted.");
}
catch (Exception ex)
{
Console.WriteLine($"插入数据时出错: {ex.Message}");
}
// 检索并显示数据以验证插入
string selectQuery = "SELECT * FROM [Sheet1$]";
OleDbDataAdapter adapter = new OleDbDataAdapter(selectQuery, connection);
DataTable dataTable = new DataTable();
adapter.Fill(dataTable);
foreach (DataRow row in dataTable.Rows)
{
foreach (var cell in row.ItemArray)
{
Console.Write(cell.ToString() + "\t");
}
Console.WriteLine();
}
}
Console.ReadKey();
}
}