sql-server – 从DbContext执行存储过程

我在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);

解决方法

DbContext提供这些功能.使用:
IEumerable<...> result = myContext.Database.sqlQuery<...>(...)

执行检索存储过程和

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

执行数据修改存储过程.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 &#39;EastRiver&#39; 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...