好吧,我显然遗漏了一些非常基本的东西。我对Entity Framework非常陌生。
我想在不导入存储过程的情况下调用它们,所以我计划使用ExecuteStoreQuery()。根据文档,ExecuteStoreQuery是ObjectContext的一种方法。但是,我不知道去哪里买我的ObjectContext。
我首先使用数据库生成了我的实体。到目前为止,我已经像这样访问了我的实体:
var db = new MyEntities();
PRODUCT p = db.PRODUCTS.First(a => a.PRODUCTSKEY == thekey);
但我不能调用db.ExecuteStoreQuery,因为数据库不是ObjectContext。
我用谷歌搜索了如何从实体获取ObjectContext。我找到了一些答案,但它们都标有警告,说这是一种变通办法,只有在你别无选择的情况下才使用它。好的,那么什么是正确的方式呢?
我找到的所有使用ExecuteStoreQuery的示例都假定您已经有了ObjectContext。不是很有帮助。
我找到一个网站,上面说ObjectContext是由实体框架“自动生成”的。如果是这样的话,它在哪里呢?
显然,我在这里遗漏了一些非常简单的东西。这不可能有那么难。
发布于 2013-01-10 03:49:39
要获得DbContext的ObjectContext,您只需执行以下操作:
var objectContext = ((IObjectContextAdapter)myDbContextObject).ObjectContext;
发布于 2013-01-10 04:00:16
在Entity Framework4.1中,ObjectContext
被DbContext
取代。实际上,DbContext
是ObjectContext
上的一个适配器(包装器)。如果您需要获取ObjectContext
,您可以将您的DbContext
实例转换为IObjectContextAdapter
接口(它是显式实现的),并且可以使用包装的ObjectContext
实例:
ObjectContext context = ((IObjectContextAdapter)db).ObjectContext;
顺便说一句,我认为你正在寻找db.Database.SqlQuery
方法。
发布于 2013-01-10 03:46:09
在您的例子中,MyEntities就是您的ObjectContext。
从技术上讲,它是由继承自ObjectContext类的EntityFramework自动生成的类。
https://stackoverflow.com/questions/14245153
复制相似问题