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"); // CustomerIdcommand.Parameters.AddWithValue("?", "John Doe"); // CustomerNamecommand.Parameters.AddWithValue("?", "john.doe@example.com"); // Emailtry{// 执行插入命令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();}
}