【问题标题】:c#: ExecuteNonQuery() returns -1c#: ExecuteNonQuery() 返回 -1
【发布时间】:2011-12-28 19:52:34
【问题描述】:

我之前使用过这种方法来返回更改的行数。我是运行插入方法,插入在存储过程中运行良好,但 ExecuteNonQuery 的返回值总是返回-1。

这是我的 C# 代码:

int ret = 0;

using (SqlConnection conn = new SqlConnection(this.ConnectionString))
{
    using (SqlCommand cmd = new SqlCommand(QueryName, conn))
    {
        conn.Open();

        if (Params != null)
            cmd.Parameters.AddRange(Params);

        cmd.CommandType = CommandType.StoredProcedure;

        ret = cmd.ExecuteNonQuery();

        conn.Close();
    }
}

return ret;

为什么我得到 -1 而不是实际更改的行数?

【问题讨论】:

  • 所以表中的修改实际上发生了,但你得到-1?
  • 它可能会返回你的存储过程返回的任何东西,如果没有另外指定,它可能是 -1..
  • 您是否真的使用分析器捕获了 SQL 调用并手动执行以查看实际更改的行号?
  • 存储过程的代码在哪里?
  • ExecuteNonQuery() 的可能重复项

标签: c# executenonquery


【解决方案1】:

如果您使用此方法调用执行的存储过程 UPDATE/INSERT 在表中,如果存储过程,该方法返回 -1 将 SET NOCOUNT 设为 ON 值。

--source

【讨论】:

    【解决方案2】:

    来自微软:

    对于 UPDATE、INSERT 和 DELETE 语句,返回值是受命令影响的行数。当正在插入或更新的表上存在触发器时,返回值包括受插入或更新操作影响的行数以及受一个或多个触发器影响的行数。对于所有其他类型的语句,返回值为 -1。如果发生回滚,返回值也是-1。

    http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlcommand.executenonquery.aspx

    您可能得到 -1,因为您使用的是存储过程而不是直接表更改

    【讨论】:

      【解决方案3】:

      您从存储过程返回什么值?你能显示你的存储过程的代码吗?您可能需要编辑存储过程以返回所需的值,或者,您的存储过程正在返回 -1,或者存储过程返回的变量的值是 -1。

      【讨论】:

        【解决方案4】:

        从存储过程中获取行计数输出,例如使用@rowCount=@@Rowcount。在 DAL 中,使用 dbManager.AddOutParameter("RowCount", DbType.Int32, rowCount); 然后在最后一行中,您将获得 (int)dbManager.GetParameterValue("RowCount")

        【讨论】:

          猜你喜欢
          • 2016-02-28
          • 1970-01-01
          • 2011-12-09
          • 1970-01-01
          • 2017-01-20
          • 2018-09-15
          • 2013-02-07
          相关资源
          最近更新 更多