Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解

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

Dapper 的 Execute 方法返回的是一个 int 类型的整数,它表示该 SQL 命令**实际影响的数据库行数**,不是执行成功与否的布尔值,也不是主键 ID 或其他业务值。

返回值就是“受影响行数”

这个数字直接对应数据库执行后报告的 rows affected。例如:

插入一条新记录且成功 → 返回 1 批量插入 5 条,全部成功 → 返回 5 UPDATE 语句匹配到 3 行,其中 2 行字段值实际发生了变化 → 多数数据库(如 SQL Server、PostgreSQL)仍返回 3(只要 WHERE 匹配就计数,不管是否真正更新了数据) DELETE 条件没匹配到任何行 → 返回 0 INSERT IGNORE 或 ON CONFLICT DO NOTHING 在发生冲突时未插入 → 返回 0(Dapper 能如实反映这一行为)

不等于“执行是否成功”

Execute 不抛异常 ≠ 操作成功;返回 0 ≠ 一定出错。它只管“行数”,异常由底层 ADO.NET 抛出(比如连接失败、语法错误、违反约束等)。所以:

返回 0 是完全合法的业务结果(如更新一个不存在的用户) 返回大于 0 也不代表业务逻辑正确(比如误删了多条) 需要结合业务语义判断:比如“新增用户”期望返回 1,若得 0 就该提示“用户名已存在”

和 Insert/Update/Delete 场景的对应关系

不同操作下返回值的典型含义:

INSERT:通常为 1(单条)或 N(批量),但含唯一键冲突时可能为 0(取决于 SQL 写法,如用
INSERT IGNORE
ON CONFLICT
UPDATE:等于 WHERE 条件命中的行数,哪怕 SET 的值和原值一样(SQL Server 默认如此;MySQL 可配置是否严格检测变更) DELETE:等于被删除的行数,可为 0(无匹配)到任意正整数 存储过程调用:默认返回的是过程内最后一条可影响行数的语句的结果;如需获取 RETURN_VALUE,必须显式用
DynamicParameters
添加
ParameterDirection.ReturnValue
参数

常见误区提醒

几个容易混淆的点:

❌ 不是自增主键值 —— 想取新 ID 请用 ExecuteScalar 配合
OUTPUT INSERTED.Id
SELECT SCOPE_IDENTITY()
❌ 不是执行耗时或状态码 —— 它纯粹是数据库返回的整数 ❌ 不会因事务回滚而返回负数 —— 回滚后 Execute 已不返回,而是抛出异常或由上层捕获 ✅ 支持批量操作 —— 传入 List 实体或匿名对象集合时,返回的是所有批次累计影响行数

基本上就这些。理解 “返回值 = 数据库说改了几行”,就能避开大多数误判。

相关推荐

热文推荐