Die*_*hon 8 sql-server entity-framework-4.1
我在SqlServer中有两个简单的存储过程:
SetData(@id int, @data varchar(10))
GetData(@id int)
.GetData
当前返回单行单列结果集,但如果需要,我可以将其更改为适当的函数.
从DbContext
实例执行这些操作的最佳方法是什么?
如果可能的话,我想避免必须进行自己的连接状态管理和/或暴露EF特定类型.我首先检索ObjectContext
并查看Execute*
函数,但文档非常糟糕,缺少涉及存储过程的示例.
理想情况下,我希望能够做到这一点:
myContext.ExecuteNonQuery("SetData", id, data);
var data = myContext.ExecuteScalar<string>("GetData", id);
Run Code Online (Sandbox Code Playgroud)
Lad*_*nka 22
DbContext提供这些功能.使用:
IEumerable<...> result = myContext.Database.SqlQuery<...>(...)
Run Code Online (Sandbox Code Playgroud)
执行检索存储过程和
int result = myContext.Database.ExecuteSqlCommand(...)
Run Code Online (Sandbox Code Playgroud)
执行数据修改存储过程.