想用 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
示例:
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示例:
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基本上就这些。Dapper 不复杂,但容易忽略连接管理、参数命名和映射细节。写熟了,你会发现它比 Entity Framework 更轻快,比纯 ADO.NET 更干净。
