
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 – 获取返回参数(声明标量变量错误)全部内容,希望文章能够帮你解决c# – EF6 – ExecuteSqlCommandAsync – 获取返回参数(声明标量变量错误)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)