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

17次阅读

Dapper的Execute方法返回int类型,表示sql命令实际影响的数据库行数;插入成功返回1,批量插入返回N,UPDATE/delete返回匹配行数,0表示无匹配或冲突未执行,不反映执行成功与否。

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

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 IGNOREON CONFLICT
  • UPDATE:等于 WHERE 条件命中的行数,哪怕 SET 的值和原值一样(SQL Server 默认如此;mysql 可配置是否严格检测变更)
  • DELETE:等于被删除的行数,可为 0(无匹配)到任意正整数
  • 存储过程调用:默认返回的是过程内最后一条可影响行数的语句的结果;如需获取 RETURN_VALUE,必须显式用 DynamicParameters 添加 ParameterDirection.ReturnValue 参数

常见误区提醒

几个容易混淆的点:

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

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

text=ZqhQzanResources