执行存储从的DbContext

问题描述:

程序我在SqlServer的两个简单的存储过程:执行存储从的DbContext

  • 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); 

的DbContext提供这些功能。使用:

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

执行检索存储的过程和

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

执行数据修改存储过程。

+0

怎么样的参数?我必须按照这里指定的方式来执行还是有快捷方式? http://stackoverflow.com/questions/4873607/how-to-use-dbcontext-database-sqlquerytelementsql-params-with-stored-procedu/4874600#4874600 – 2011-06-08 18:32:06

+0

这是一种方法。它也应该工作而不使用'SqlParameter' - 只传递值。我不确定在直接使用值时,是否不必通过@ p0,@ p1等引用它们。 – 2011-06-08 18:55:22

+0

我最终传递了一个匿名对象并将其转换为SqlParameters内​​部。 – 2011-06-08 19:29:03