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

想用 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
-
Query
(sql, param) → 返回 IEnumerable,适合列表查询 -
QueryFirstOrDefault
(sql, param) → 返回单个对象或 null,适合按 ID 查一条 - 参数用匿名对象传,如 new { id = 123 },Dapper 自动转为 SQL 参数,防注入
示例:
using (var conn = new SqlConnection(connStr))
{
var users = conn.Query("SELECT * FROM Users WHERE Age > @age", new { age = 18 });
var user = conn.QueryFirstOrDefault("SELECT * FROM Users WHERE Id = @id", new { id = 1 });
} 执行增删改:Execute 方法
插入、更新、删除统一用 Execute(),返回影响行数(int):
- 支持普通 SQL + 参数化,也支持批量操作(配合事务更稳)
- 插入后想获取自增 ID?用 ExecuteScalar
("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
(..., splitOn: "CustomerId") - 别忘了开连接:conn.Open(),Dapper 不自动打开;用 using 确保释放
基本上就这些。Dapper 不复杂,但容易忽略连接管理、参数命名和映射细节。写熟了,你会发现它比 Entity Framework 更轻快,比纯 ADO.NET 更干净。










