当前位置: 首页 > article >正文

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();
    }
}


http://www.kler.cn/news/289308.html

相关文章:

  • K8s 节点管理:使用 kubeadm 删除和重新添加 Kubernetes 节点
  • 软件架构设计——DCI 范型
  • uni-app支持Vue 3的组件库推荐几个
  • 创新之光闪耀,点赋科技在第十三届创新创业大赛中绽放光彩
  • Django form.save 方法的详细分析
  • 毕业设计选题系统
  • 前段框架有哪些
  • 一起学习LeetCode热题100道(65/100)
  • 数据结构基本知识
  • Rust: Web框架Axum和Rest Client协同测试
  • 从 Oracle 到 TiDB 丨数据库资源评估指南
  • CUDA与TensorRT学习一:并行处理与GPU体系架构
  • 名城优企游学活动走进龙腾半导体:CRM助力构建营销服全流程体系
  • nginx部署前段VUE项目
  • wsl2 无法上网解决方法
  • 文本文件完整性判断-加密
  • Python中排序算法之冒泡排序
  • Soul Machines——AI生成虚拟主播或虚拟人,模拟真人交互
  • 后端MVC三层架构,Mybatis ,雪花算法生成唯一id
  • 『功能项目』销毁怪物蛋的Shaders消融特效【17】
  • SpringDataJPA系列(5)@Query应该怎么用?
  • QT connect的使用
  • 算法练习题11:单词出现次数
  • Android kotlin使用Netty网络框架实践(客户端、服务端)
  • 新版Pycharm的Available Packages里面为空,新版没有Manage Repositories功能,如何解决
  • OpenGL/GLUT实践:弹簧-质量-阻尼系统模拟摆动的绳子和布料的物理行为(电子科技大学信软图形与动画Ⅱ实验)
  • 《React Hooks:让你的组件更灵活》
  • Android之电量优化
  • 【论文笔记】Multi-Task Learning as a Bargaining Game
  • 4.3 python 编辑单元格