使用Entity Framework从存储过程获取数据
我正在尝试使用从数据库上下文对象(使用Entity Framework
6.1.1)调用的动态SQL存储过程来获取表的内容,以便填充GridView
控件。我无法检索数据。
这是存储过程。这是一个有关存储过程中SQL注入的学生演示,所以 这是可注入的,也很好。
ALTER PROCEDURE dbo.SearchProducts @SearchTerm VARCHAR(max)
AS
BEGIN
DECLARE @query VARCHAR(max)
SET @query = 'SELECT * FROM dbo.Products WHERE Name LIKE ''%' + @SearchTerm + '%'''
EXEC(@query)
END
我随后用来执行存储过程的C#代码是:
var db = new MyEntities();var TEST_SEARCH_TERM = "product";
var result = db.SearchProducts(TEST_SEARCH_TERM);
MyGridView.DataSource = result;
MyGridView.DataBind();
在执行时,在Visual
Studio的数据库资源管理器中,存储过程可以正常工作。但是,当在运行中的ASP.NET应用程序中执行该DataBind()
方法时,我在该方法中遇到了一个异常,因为result
返回-1
而不是IEnumerable
DataSet
包含存储过程的SELECT生成的对象。
如何获取数据并填充我的数据GridView
?
回答:
使用以下步骤解决此问题:
- 您需要将存储过程导入为函数。右键单击实体模型的工作区,然后选择
Add -> Function Import
。 - 在“添加函数导入”对话框中,输入要在模型中引用存储过程的名称,例如
Search_Products
,从下拉列表中选择过程,然后选择该过程的返回值,然后从下拉列表中进行Entities
选择Products
。清单。 然后在后面的代码中:
var db = new MyEntities();
var TEST_SEARCH_TERM = “product”;
var result = db.Search_Products(TEST_SEARCH_TERM);//Search_Products is the name that you specified in Function Import dialog
MyGridView.DataSource = result;
MyGridView.DataBind();
获得-1
结果的原因是Entity Framework无法直接支持存储过程返回值。我认为对存储过程返回值的支持取决于Entity
Framework的版本。另外,Entity Framework不具有丰富的存储过程支持,因为它是ORM而不是SQL的替代品。
以上是 使用Entity Framework从存储过程获取数据 的全部内容, 来源链接: utcz.com/qa/399870.html