C#通过ACE OLEDB驱动程序访问 Access和 Excel

ACE 代表 Access Connectivity Engine。它是 Microsoft 提供的一组组件,用于访问和操作 Microsoft Access 数据库以及其他类似的文件格式,如 Excel 工作簿。ACE 主要包括以下几部分:

  1. ACE OLEDB 驱动程序:用于通过 OLE DB 提供程序访问 Access 数据库和 Excel 文件。例如,Microsoft.ACE.OLEDB.12.0 是一个常见的提供程序版本,用于访问 Access 2007 及以上版本的数据库以及 Excel 2007 及以上版本的工作簿。

  2. Access Database Engine:这是一个包含 ACE OLEDB 驱动程序的组件。它允许应用程序读取和写入 Access 数据库文件(.accdb.mdb 文件)以及 Excel 文件(.xls.xlsx 文件)。

  3. 数据源提供程序: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();
    }
}

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值