我有以下代码:
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.查看更多关于c# – EF6 – ExecuteSqlCommandAsync – 获取返回参数(声明标量变量错的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did69297