c#:ExecuteNonQuery()返回-1

我之前使用过这种方法来返回更改的行数。 我是运行insert方法,插入在存储过程中运行正常,但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而不是更改的实际行数?

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

– 来源

来自微软:

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

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

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

您从存储过程返回什么值? 您能否显示存储过程的代码。 您可能需要编辑存储过程以返回所需的值,或者,存储过程返回-1,或者存储过程返回的变量具有-1作为其值。

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