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

来源:这里教程网 时间:2026-02-21 17:40:53 作者:

想用 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()QueryFirstOrDefault()

Query(sql, param) → 返回 IEnumerable,适合列表查询 QueryFirstOrDefault(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("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 更干净。

相关推荐