商城首页欢迎来到中国正版软件门户

您的位置:首页 >C# Dapper教程 Dapper基础用法详解

C# Dapper教程 Dapper基础用法详解

  发布于2026-02-18 阅读(0)

扫一扫,手机访问

Dapper 是轻量高效 ORM,通过扩展方法简化 ADO.NET 操作,支持 Query/QueryFirstOrDefault/Execute 等核心方法,参数化防注入,需手动管理连接,映射支持 Column 特性与 SplitOn 多表拆分。

C# Dapper入门教程 Dapper基础用法快速上手

想用 C# 快速操作数据库,又不想写一堆 ADO.NET 冗余代码?Dapper 是个极简但高效的 ORM 选择——它不替换 SqlCommand,而是帮你省掉重复的映射和参数处理,性能接近原生 SQL,学习成本却很低。

安装与基础配置

Dapper 是一个 NuGet 包,不是框架,所以无需注册服务或配置依赖注入(当然你也可以集成进 DI)。只需在项目中安装:

  • Install-Package Dapper(.NET Framework 或 .NET Core/5+ 都支持)
  • 确保已有 System.Data.SqlClient(SQL Server)或 Microsoft.Data.SqlClient(推荐新版)
  • using Dapper; 别忘了加命名空间

执行查询:Query 与 QueryFirstOrDefault

Dapper 的核心是扩展方法,直接挂在 IDbConnection 上。最常用的是 Query<T>()QueryFirstOrDefault<T>()

  • Query<User>(sql, param) → 返回 IEnumerable<User>,适合列表查询
  • QueryFirstOrDefault<User>(sql, param) → 返回单个对象或 null,适合按 ID 查一条
  • 参数用匿名对象传,如 new { id = 123 },Dapper 自动转为 SQL 参数,防注入

示例:

using (var conn = new SqlConnection(connStr))
{
    var users = conn.Query<User>("SELECT * FROM Users WHERE Age > @age", new { age = 18 });
    var user = conn.QueryFirstOrDefault<User>("SELECT * FROM Users WHERE Id = @id", new { id = 1 });
}

执行增删改:Execute 方法

插入、更新、删除统一用 Execute(),返回影响行数(int):

  • 支持普通 SQL + 参数化,也支持批量操作(配合事务更稳)
  • 插入后想获取自增 ID?用 ExecuteScalar<int>("INSERT...; SELECT SCOPE_IDENTITY();", param)
  • 注意:Execute 不自动开启事务,需要手动用 conn.BeginTransaction()

示例:

var rows = conn.Execute(
    "UPDATE Users SET Name = @name WHERE Id = @id", 
    new { name = "张三", id = 1 }); // 返回 1 表示成功更新一行

映射技巧与常见注意点

Dapper 默认按列名(case-insensitive)匹配类属性,但实际开发中常遇到不一致的情况:

  • 数据库字段用 user_name,C# 属性叫 UserName?加 [Column("user_name")] 特性(需引用 System.ComponentModel.DataAnnotations.Schema
  • 查询含多表 JOIN?用匿名类型或自定义 DTO,Dapper 支持自动拆分(SplitOn),比如 Query<Order, Customer, Order>(..., splitOn: "CustomerId")
  • 别忘了开连接:conn.Open(),Dapper 不自动打开;用 using 确保释放

基本上就这些。Dapper 不复杂,但容易忽略连接管理、参数命名和映射细节。写熟了,你会发现它比 Entity Framework 更轻快,比纯 ADO.NET 更干净。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注