EF6 – ExecuteSqlCommandAsync – 获取返回参数(声明标量变量错误)
我有以下代码:
object[] parameters = { new SqlParameter("@val1", val1), new SqlParameter("@val2", val2), new SqlParameter { ParameterName = "@retVal", SqlDbType = SqlDbType.Int, Direction = ParameterDirection.ReturnValue, Value = -1 } }; await context.Database.ExecuteSqlCommandAsync("EXEC @retVal = Example_SP @val1, @val2", parameters);
我正在使用的SP很好,并在SQL MS中返回一个值。 但是当我使用EF执行它时,我被告知我必须声明标量变量@retVal’。 这不是我的SqlParameter吗?
我已经尝试从参数中移除’@’符号,正如一些人在其他地方所建议的那样,但据我所知,’@’符号是可选的,无论如何都没有区别。
如何使用ExecuteSqlCommandAsync从SP获取返回值而不会导致错误?
谢谢!
您需要使用ParameterDirection.Output
而不是ParameterDirection.ReturnValue
。