从DbContext执行存储过程

时间:2011-06-08 16:58:39

标签: 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);

1 个答案:

答案 0 :(得分:22)

DbContext提供这些功能。使用:

IEumerable<...> result = myContext.Database.SqlQuery<...>(...)

执行检索存储过程和

int result = myContext.Database.ExecuteSqlCommand(...)

执行数据修改存储过程。