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"); // 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();}
}
System.Data.OleDb
命名空间提供了一组类,用于通过 OLE DB 提供程序与数据库进行交互。主要涉及的类和它们的关键方法和属性如下:
1. OleDbConnection
- 作用: 用于与数据源建立连接。
- 主要属性:
ConnectionString
: 获取或设置连接字符串。State
: 获取当前连接状态。
- 主要方法:
Open()
: 打开与数据源的连接。Close()
: 关闭与数据源的连接。
2. OleDbCommand
- 作用: 表示要发送到数据源的 SQL 语句或存储过程。
- 主要属性:
CommandText
: 获取或设置要执行的 SQL 语句或存储过程的名称。CommandType
: 获取或设置命令的类型(如Text
或StoredProcedure
)。Connection
: 获取或设置与OleDbCommand
关联的OleDbConnection
对象。
- 主要方法:
ExecuteReader()
: 执行命令并返回OleDbDataReader
。ExecuteNonQuery()
: 执行命令而不返回结果(如 INSERT、UPDATE、DELETE)。ExecuteScalar()
: 执行命令并返回单一值(通常是聚合函数结果)。
3. OleDbDataReader
- 作用: 以只读、向前的方式读取数据。
- 主要属性:
FieldCount
: 获取结果集中列的数量。HasRows
: 指示是否存在行。
- 主要方法:
Read()
: 读取下一行数据。GetString(int ordinal)
: 获取指定列的字符串值(可以用GetInt32
、GetDouble
等方法读取其他数据类型)。GetValue(int ordinal)
: 获取指定列的值(返回object
类型)。
4. OleDbDataAdapter
- 作用: 用于填充
DataSet
并更新数据源。 - 主要属性:
SelectCommand
: 获取或设置用于填充DataSet
的OleDbCommand
。InsertCommand
,UpdateCommand
,DeleteCommand
: 分别用于插入、更新和删除数据的OleDbCommand
。
- 主要方法:
Fill(DataSet dataSet)
: 填充DataSet
。Update(DataSet dataSet)
: 更新数据源中的数据。
5. OleDbParameter
- 作用: 表示要添加到
OleDbCommand
中的参数。 - 主要属性:
ParameterName
: 获取或设置参数的名称。Value
: 获取或设置参数的值。DbType
: 获取或设置参数的数据类型。Size
: 获取或设置参数的大小(适用于字符串和二进制数据)。
这些类和方法提供了通过 OLE DB 访问和操作数据的基本功能。
using System;
using System.Data;
using System.Data.OleDb;
using System.Windows.Forms;namespace ExcelToDataGridView
{public partial class Form1 : Form{private DataGridView dataGridView1;public Form1(){// InitializeComponent();InitializeDataGridView();LoadExcelData();}private void InitializeDataGridView(){dataGridView1 = new DataGridView{Dock = DockStyle.Fill,AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill,AllowUserToAddRows = false,AllowUserToDeleteRows = false};this.Controls.Add(dataGridView1);}private void LoadExcelData(){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)){try{connection.Open();DataTable schemaTable = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);string sheetName = schemaTable.Rows[0]["TABLE_NAME"].ToString();string query = $"SELECT * FROM [{sheetName}]";OleDbDataAdapter dataAdapter = new OleDbDataAdapter(query, connection);DataTable dataTable = new DataTable();dataAdapter.Fill(dataTable);dataGridView1.DataSource = dataTable;}catch (Exception ex){MessageBox.Show($"Error: {ex.Message}");}}}}static class Program{[STAThread]static void Main(){Application.EnableVisualStyles();Application.SetCompatibleTextRenderingDefault(false);Application.Run(new Form1());}}
}
相关文章:

C#通过ACE OLEDB驱动程序访问 Access和 Excel
ACE 代表 Access Connectivity Engine。它是 Microsoft 提供的一组组件,用于访问和操作 Microsoft Access 数据库以及其他类似的文件格式,如 Excel 工作簿。ACE 主要包括以下几部分: ACE OLEDB 驱动程序:用于通过 OLE DB 提供程序…...

智能新纪元:GPT-Next引领的AI革命及其跨领域应用
GPT-Next:性能的百倍提升 在当今这个科技日新月异的时代,人工智能(AI)无疑是最具活力和变革性的领域之一。最近,OpenAI在KDDI峰会上宣布了一项激动人心的消息:他们即将推出名为“GPT-Next”的新一代语言模…...

Nexus配置npm私服
1,配置npm-hub 2,配置proxy-npm 3,配置group-npm 4,配置local-npm 5,配置淘宝...

《OpenCV计算机视觉》—— 图像轮廓检测与绘制
文章目录 一、轮廓的检测二、轮廓的绘制图像轮廓检测与绘制的代码实现 三、轮廓的近似 一、轮廓的检测 轮廓检测是指在包含目标和背景的数字图像中,忽略背景和目标内部的纹理以及噪声干扰的影响,采用一定的技术和方法来实现目标轮廓提取的过程注意:做轮…...

Spark-Yarn模式如何配置历史服务器
在Spark程序结束之后我们也想看到运行过程怎么办? Yarn模式下,通过以下步骤配置历史服务器即可: mv spark-defaults.conf.template spark-defaults.conf修改spark-default.conf 文件,配置日志存储路径 spark.eventLog.enabled true spark.…...

Maven的安装
一、安装 压缩包解压完的目录如下所示(此处为绿色免安装版): (其余三个文件是针对Maven版本,第三方软件等简要介绍) 二、环境变量 前提: jdk最低版本为JAVA7(即jdk17)…...

iOS——APP启动流程
APP启动 APP启动主要分为两个阶段:pre-main和main之后,而APP的启动优化也主要是在这两个阶段进行的。 main之后的优化:1. 减少不必要的任务,2.必要的任务延迟执行,例如放在控制器界面等等。 APP启动的大致过程&#…...

LLM模型:代码讲解Transformer运行原理
视频讲解、获取源码:LLM模型:代码讲解Transformer运行原理(1)_哔哩哔哩_bilibili 1 训练保存模型文件 2 模型推理 3 推理代码 import torch import tiktoken from wutenglan_model import WutenglanModelimport pyttsx3# 设置设备为CUDA(如果…...

虚幻引擎VR游戏开发02 | 性能优化设置
常识:VR需要保持至少90 FPS的刷新率,以避免用户体验到延迟或晕眩感。以下是优化性能的一系列设置(make sure the frame rate does not drop below a certain threshold) In project setting-> (以下十个设置都在pr…...

Web应用监控:URL事务监测指标解读
监控易是一款功能强大的IT监控软件,它能够实时监控各种IT资源和应用的运行状态,确保业务的连续性和稳定性。在Web应用监控方面,监控易提供了URL事务监测功能,通过模拟用户访问流程,监测整个事务的执行过程和性能表现。…...

redis之缓存淘汰策略
1.查看redis的最大占用内存 使用redis-cli命令连接redis服务端,输入命令:config get maxmemory 输出的值为0,0代表redis的最大占用内存等同于服务器的最大内存。 2.设置redis的最大占用内存 编辑redis的配置文件,并重启redis服务…...

CMake/C++:一个日志库spdlog
项目仓库 GitHub - gabime/spdlog: Fast C logging library.Fast C logging library. Contribute to gabime/spdlog development by creating an account on GitHub.https://github.com/gabime/spdlog 知乎参考贴 https://zhuanlan.zhihu.com/p/674073158 先将仓库clone一下 然…...

rig——管理不同R语言版本的工具
在Python中,我可以用Conda去管理多个版本的Python,包括一些Python模块,因此想在R语言中也找一个类似的工具。 之前在Mac上,有一个名为 Rswitch 的R语言版本管理工具,可以管理不同版本的R以及相应的R包。 现在想在Win…...

Java内存模型详解
1. 引言 在Java中,内存模型是非常重要的概念,它涉及到线程之间如何共享数据以及保证数据的一致性。了解Java内存模型对于开发高质量的多线程程序是至关重要的。 本篇博客将详细介绍Java内存模型的概念、原则、规则以及相关的概念和术语。同时ÿ…...

空气能热泵热水器
空气能热泵热水器压缩机把低温低压气态冷媒转换成高压高温气态,压缩机压缩功能转化的热量为q1,高温高压的气态冷媒与水进行热交换,高压的冷媒在常温下被冷却、冷凝为液态。这过程中,冷媒放出热量用来加热水,使水升温变…...

计算机毕业设计选题推荐-消防站管理系统-社区消防管理系统-Java/Python项目实战
✨作者主页:IT毕设梦工厂✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…...

移动UI:新手指引页面,跟着指引不迷路。
移动端新手指引在提供用户引导、提升用户体验、提高用户留存率、促进功能使用和降低用户流失率方面都有积极的作用。 移动端新手指引在应用程序或移动网站中有以下几个作用: 1. 提供用户引导: 新手指引可以帮助用户快速了解应用程序或移动网站的功能和…...

数据库MySQL基础
目录 一、数据库的介绍 1.数据库概述 (1)数据的存储方式 (2)数据库 2.常见数据库排行榜 二、数据库的安装与卸载 1.数据库的安装 2.数据库的卸载 三、数据库服务的启动与登录 1.Windows 服务方式启动 (1&…...

AUTOSAR_EXP_ARAComAPI的5章笔记(3)
5.3.4 Finding Services Proxy Class提供类(静态)方法来查找“连接”的服务实例。由于服务实例的可用性本质上是动态的(因为它有一个生命周期),所以ara::com提供了如下两种不同的方法来实现“FindService ”: StartFindService是一个类方法,它在后台启…...

【Godot4.3】基于纯绘图函数自定义的线框图控件
概述 同样是来自2023年7月份的一项实验性工作,基于纯绘图函数扩展的一套线框图控件。初期只实现了三个组件,矩形、占位框和垂直滚动条。 本文中的三个控件类已经经过了继承化的修改,使得代码更少。它们的继承关系如下: 源代码 W…...

申万宏源证券完善金融服务最后一公里闭环,让金融服务“零距离、全天候”
在数字化转型的浪潮中,申万宏源作为金融行业的先锋,持续探索科技如何赋能金融服务,以提升企业效率并优化客户服务体验。面对日益增长的视频化需求,传统的图文形式已难以满足市场与用户的新期待。为了应对这一挑战,申万…...

无需更换摄像头,无需施工改造,降低智能化升级成本的智慧工业开源了。
智慧工业视觉监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上…...

系统架构师考试学习笔记第三篇——架构设计高级知识(19)嵌入式系统架构设计理论与实践
本章考点: 第19课时主要学习嵌入式系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分)。在历年考试中,案例题对该部分内容都有固定考查,综合知识选择题目中有固定分值…...

centos8stream 修改为阿里云yum源
centos8stream 官方已经不再维护,导致该系统官方源实效,可以使用阿里云源进行替换 阿里云文档:centos-vault镜像_centos-vault下载地址_centos-vault安装教程-阿里巴巴开源镜像站 (aliyun.com) 咱们只需要执行下面命令,即可替换官…...

python转换并提取pdf文件中的图片
#安装fitz包 pip install pymupdf 脚本如下所示: import fitz import re import os import time import sysarguments sys.argvfor arg in arguments:print(arg)def file_name_list(base_dir):for i, j, k in os.walk(base_dir):name [i.replace(.pdf, ) for i …...

【MySQL】MySQL常用的数据类型——表的操作
前言: 🌟🌟本期讲解关于MySQL常用数据类型,表的简单使用,希望能帮到屏幕前的你。 🌈上期博客在这里:http://t.csdnimg.cn/wwaqe 🌈感兴趣的小伙伴看一看小编主页:GGBondl…...

自然语言处理系列五十三》文本聚类算法》文本聚类介绍及相关算法
注:此文章内容均节选自充电了么创始人,CEO兼CTO陈敬雷老师的新书《自然语言处理原理与实战》(人工智能科学与技术丛书)【陈敬雷编著】【清华大学出版社】 文章目录 自然语言处理系列五十三文本聚类算法》文本聚类介绍及相关算法K…...

计算机网络(一) —— 网络基础入门
目录 一,关于网络 二,协议 2.1 协议是什么,有什么用? 2.2 协议标准谁定的? 2.3 协议分层 2.4 OSI 七层模型 2.5 TCP/IP 四层模型 三,网络传输基本流程 3.1 局域网中两台主机通信* 3.2 报文的封装与…...

从监控到智能:EasyCVR视频汇聚平台助力加油站安全监管升级转型
随着科技的不断进步,视频监控技术在各个行业的应用日益广泛,尤其在加油站这一关键领域,视频智能监管系统的应用显得尤为重要。TSINGSEE青犀视频EasyCVR视频汇聚平台作为一款基于“云-边-端”一体化架构的视频融合与AI智能分析平台,…...

日志服务管理
系统日志管理 sysklogd 系统日志服务 在 CentOS5 以及之前的发行版中,其采用的 sysklogd 服务来记录和管理系统日志的。 sysklogd 服务有两个模块: klogd: 用于记录 linux kernel 相关的日志 syslogd:用于记录用户空间应用日志…...