ADO.NET是.NET框架中用于访问数据的重要技术,它提供了与数据源交互的高效方式,支持连接到多种数据库系统,如SQL Server、Oracle、MySQL等,本文将详细介绍如何使用ADO.NET连接数据库,涵盖核心对象、连接步骤、代码示例及最佳实践,帮助开发者快速掌握数据库连接技术。

ADO.NET核心对象
ADO.NET通过一系列核心对象实现数据访问,理解这些对象的功能是连接数据库的基础:
- Connection对象:负责与数据源建立连接,是所有操作的前提,不同数据库需使用不同的连接字符串,例如SQL Server使用
SqlConnection,Oracle使用OracleConnection。 - Command对象:用于执行SQL语句或存储过程,支持查询、插入、更新和删除操作,通过
Command对象可以指定要执行的命令文本和参数。 - DataReader对象:提供只读、 forward-only 的数据流,适用于快速读取查询结果,占用较少资源。
- DataAdapter对象:作为数据源与DataSet之间的桥梁,用于填充DataSet并更新数据库,支持断开式数据操作。
- DataSet对象:内存中的数据缓存,可存储多个表和关系,支持离线数据操作。
连接数据库的详细步骤
配置连接字符串
连接字符串是建立数据库连接的关键,包含服务器地址、数据库名称、用户凭据等信息,以SQL Server为例,连接字符串格式如下:
Server=服务器名;Database=数据库名;User Id=用户名;Password=密码;
- 对于本地SQL Server Express实例,可简化为:
Server=.\SQLEXPRESS;Database=TestDB;Integrated Security=True;(Integrated Security=True表示使用Windows身份验证)。 - 建议将连接字符串存储在配置文件(如
App.config)中,便于管理和修改:<connectionStrings> <add name="MyDbConnection" connectionString="Server=服务器名;Database=数据库名;User Id=用户名;Password=密码;" providerName="System.Data.SqlClient"/> </connectionStrings>
创建并打开Connection对象
使用SqlConnection类创建连接对象,并通过Open()方法建立连接:

using System.Data.SqlClient;
string connectionString = "Server=服务器名;Database=数据库名;User Id=用户名;Password=密码;";
using (SqlConnection connection = new SqlConnection(connectionString))
{
connection.Open();
// 执行数据库操作
}
- 使用
using语句确保连接在使用完毕后自动关闭,避免资源泄漏。 - 打开连接前,可通过
State属性检查连接状态,避免重复打开。
执行Command并获取数据
(1)执行查询并使用DataReader读取
string query = "SELECT * FROM Users WHERE Age > @Age";
using (SqlCommand command = new SqlCommand(query, connection))
{
command.Parameters.AddWithValue("@Age", 25); // 参数化查询防止SQL注入
using (SqlDataReader reader = command.ExecuteReader())
{
while (reader.Read())
{
Console.WriteLine($"ID: {reader["Id"]}, Name: {reader["Name"]}");
}
}
}
- 参数化查询是防止SQL注入的最佳实践,尤其适用于用户输入的场景。
DataReader的Read()方法逐行读取数据,读取完成后需手动关闭。
(2)使用DataAdapter填充DataSet
string query = "SELECT * FROM Products";
using (SqlDataAdapter adapter = new SqlDataAdapter(query, connection))
{
DataSet dataSet = new DataSet();
adapter.Fill(dataSet, "Products");
// 对DataSet进行操作,如绑定到控件或修改数据
}
DataAdapter的Fill()方法将查询结果加载到DataSet中,支持离线操作。- 修改
DataSet后,可通过adapter.Update()将更改写回数据库。
处理异常与事务
数据库操作可能因网络问题或权限失败,需通过try-catch捕获异常:
try
{
connection.Open();
// 执行操作
}
catch (SqlException ex)
{
Console.WriteLine($"数据库错误: {ex.Message}");
}
finally
{
connection.Close(); // 确保连接关闭
}
- 对于需要原子性操作的场景(如转账),可使用事务:
using (SqlTransaction transaction = connection.BeginTransaction()) { try { command1.Transaction = transaction; command2.Transaction = transaction; command1.ExecuteNonQuery(); command2.ExecuteNonQuery(); transaction.Commit(); } catch { transaction.Rollback(); } }
不同数据库的连接差异
- Oracle数据库:需安装
Oracle.ManagedDataAccessNuGet包,使用OracleConnection和OracleCommand。 - MySQL数据库:需安装
MySql.DataNuGet包,连接字符串示例:Server=localhost;Database=test;Uid=root;Pwd=;。
最佳实践
- 连接池管理:ADO.NET默认启用连接池,频繁打开和关闭连接时,连接池会复用连接,提高性能。
- 异步操作:使用
async/await避免阻塞UI线程,例如connection.OpenAsync()。 - 安全性:避免在代码中硬编码密码,使用配置文件加密或Windows身份验证。
- 资源释放:确保
Connection、Command、DataReader等对象实现IDisposable接口,通过using或手动Dispose()释放资源。
相关问答FAQs
问题1:如何解决“登录失败,用户未授予对数据库的访问权限”错误?
解答:此错误通常由身份验证或权限问题导致,检查连接字符串中的用户名和密码是否正确,确认该用户对目标数据库具有CONNECT权限,若使用Windows身份验证,确保运行程序的用户账户有访问权限,在SQL Server中,可通过SSMS登录后执行GRANT CONNECT TO 用户名;授予权限。
问题2:ADO.NET与Entity Framework(EF)的主要区别是什么?
解答:ADO.NET是底层数据访问技术,需手动编写SQL语句和对象映射代码,控制力强但开发效率较低;Entity Framework是ORM框架,通过LINQ自动生成SQL,支持代码优先和数据库优先模式,简化开发但性能开销略高,高性能场景或复杂SQL操作适合ADO.NET,快速开发中小型项目可选择EF。
