news 2026/3/26 7:39:56

吃透 ADO.NET 核心对象,轻松搞定数据库操作

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
吃透 ADO.NET 核心对象,轻松搞定数据库操作

在 C# 开发中,和数据库打交道是家常便饭,而ADO.NET就是我们操作数据库的“得力助手”。
它的核心对象各司其职,搭配起来即可完成数据的增、删、改、查

本文将系统梳理 ADO.NET 的核心对象、协作流程,并提供完整可用的分页查询实战代码,非常适合作为学习笔记或博客文章直接发布。


一、ADO.NET 核心对象(一个都不能少)

ADO.NET 的数据库操作围绕以下几个核心对象展开,它们分工明确、各司其职。

1️⃣ Connection —— 数据库的“连接器”

作用
负责建立应用程序与数据库之间的物理连接,没有它,所有数据库操作都无法进行。

常用方法

  • Open():打开数据库连接
  • Close():关闭数据库连接

Close vs Dispose 的区别

方法说明
Close()关闭连接,但对象仍可再次Open()
Dispose()释放所有资源,对象不可再使用

最佳实践:使用using语句,自动释放资源。


2️⃣ Command —— 数据库的“指令官”

作用
依附于Connection,用于向数据库发送 SQL 指令或调用存储过程。

核心属性

  • CommandText:SQL 语句或存储过程名
  • Connection:关联的数据库连接
  • CommandTypeText/StoredProcedure

常用方法

  • ExecuteNonQuery():执行增删改,返回受影响行数
  • ExecuteScalar():返回第一行第一列的值
  • ExecuteReader():返回DataReader

3️⃣ DataAdapter —— 数据的“搬运工”

作用
连接数据库DataSet的桥梁,负责数据的读取与回写。

核心方法

  • Fill():从数据库填充 DataSet
  • Update():将 DataSet 的更改同步回数据库

📌 特点:

  • 无需手动管理连接
  • Fill()会自动打开并关闭连接

4️⃣ DataSet —— 内存中的“数据库副本”

作用
用于在内存中暂存数据,完全脱离数据库连接进行操作。

组成结构

DataSet ├── DataTable │ ├── DataRow │ └── DataColumn

优势

  • 支持离线操作
  • 可保存表结构、主键、表关系
  • 适合复杂业务处理

5️⃣ DataReader —— 高性能“数据阅读器”

适用场景
只读、高性能、顺序读取数据。

核心特点

  • 只读(ReadOnly)
  • 只进(ForwardOnly)
  • 极低内存占用

⚠️ 注意事项:

  • 使用期间Connection 必须保持打开
  • 读取完成后必须及时关闭连接

二、ADO.NET 核心对象协作流程

完整的数据库操作流程如下:

  1. 使用Connection打开数据库连接
  2. 使用CommandDataAdapter执行 SQL
  3. 查询结果:
    • 快速读取 →DataReader
    • 离线操作 →DataSet / DataTable
  4. 执行业务逻辑处理

三、实战示例:ADO.NET 分页查询(完整版)

以下示例基于ROW_NUMBER()实现分页,包含:

  • 参数化 SQL
  • DataSet 查询
  • DataTable 转实体

1️⃣ 业务层:分页入口

publicList<Books>GetPageList(intpageIndex,intpageSize){intstart=(pageIndex-1)*pageSize+1;intend=pageIndex*pageSize;DataSetds=dal.GetPageList(start,end);returnDataTableToList(ds.Tables[0]);}

2️⃣ 数据访问层:分页 SQL

publicDataSetGetPageList(intstart,intend){stringsql=@" SELECT * FROM ( SELECT *, ROW_NUMBER() OVER(ORDER BY Id) AS Num FROM Books ) t WHERE t.Num >= @start AND t.Num <= @end";SqlParameter[]ps={newSqlParameter("@start",SqlDbType.Int),newSqlParameter("@end",SqlDbType.Int)};ps[0].Value=start;ps[1].Value=end;returnSqlHelper.Query(sql,CommandType.Text,ps);}

3️⃣ DataTable → 实体列表

publicList<Books>DataTableToList(DataTabledt){List<Books>list=newList<Books>();foreach(DataRowrowindt.Rows){Booksmodel=newBooks();model.Id=row["Id"]!=DBNull.Value?Convert.ToInt32(row["Id"]):0;model.Title=row["Title"].ToString();model.Author=row["Author"].ToString();model.ISBN=row["ISBN"].ToString();if(row["PublishDate"]!=DBNull.Value)model.PublishDate=Convert.ToDateTime(row["PublishDate"]);if(row["UnitPrice"]!=DBNull.Value)model.UnitPrice=Convert.ToDecimal(row["UnitPrice"]);list.Add(model);}returnlist;}

四、ADO.NET 实战优化技巧(必看)

✅ 1. 使用配置文件管理连接字符串

  • App.config / Web.config
  • 避免硬编码,方便环境切换

✅ 2. 封装 SqlHelper 工具类

  • 统一管理 Connection / Command
  • 减少重复代码,提高可维护性

✅ 3. 坚决使用参数化查询

  • 防止 SQL 注入
  • 提升 SQL 执行计划复用率

✅ 4. using 语句释放资源

using(SqlConnectionconn=newSqlConnection(connStr)){conn.Open();...}

五、总结

ADO.NET 虽然不像 EF Core 那样“开箱即用”,但它是所有 ORM 框架的底层基础

👉理解 ADO.NET = 理解数据库访问本质
👉会 ADO.NET = ORM 再复杂也不慌

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 15:17:19

DriverStore Explorer完整指南:一键搞定Windows驱动管理难题

DriverStore Explorer完整指南&#xff1a;一键搞定Windows驱动管理难题 【免费下载链接】DriverStoreExplorer Driver Store Explorer [RAPR] 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer 还在为Windows系统驱动问题烦恼吗&#xff1f;DriverSto…

作者头像 李华
网站建设 2026/3/14 18:30:20

大模型性能优化方向

目录 文章目录目录经典优化方向显存优化技术训练优化器ZeROCheckpointing activation混合精度训练计算优化技术降低计算精度&#xff08;Precision Reduction&#xff09;算子融合&#xff08;Kernel Fusion&#xff09;重计算/激活检查点&#xff08;Recomputation/Activation…

作者头像 李华
网站建设 2026/3/21 4:54:36

DriverStore Explorer:Windows驱动管理神器完全揭秘

DriverStore Explorer&#xff1a;Windows驱动管理神器完全揭秘 【免费下载链接】DriverStoreExplorer Driver Store Explorer [RAPR] 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer 还在为Windows驱动问题烦恼吗&#xff1f;DriverStore Explorer这…

作者头像 李华
网站建设 2026/3/13 19:56:34

Joy-Con Toolkit完整教程:从零开始掌握手柄自定义技巧

Joy-Con Toolkit完整教程&#xff1a;从零开始掌握手柄自定义技巧 【免费下载链接】jc_toolkit Joy-Con Toolkit 项目地址: https://gitcode.com/gh_mirrors/jc/jc_toolkit 想要充分发挥任天堂Switch手柄的潜力吗&#xff1f;Joy-Con Toolkit作为一款专业的开源工具&…

作者头像 李华
网站建设 2026/3/24 4:14:44

1小时验证创意:MODBUS调试助手的5种创新形态原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 生成多形态MODBUS调试原型套件&#xff0c;包含&#xff1a;1. 微信小程序版&#xff08;扫码即用&#xff09;2. 浏览器Web串口版 3. 终端命令行版 4. 桌面插件版 5. REST API服务…

作者头像 李华
网站建设 2026/3/25 0:08:19

ARM64 vs x86:开发效率对比实测报告

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个跨架构性能对比工具&#xff0c;能够自动在ARM64和x86平台上运行相同的算法代码&#xff0c;收集并可视化比较编译时间、执行速度和功耗数据。使用快马平台生成多架构兼容…

作者头像 李华