实体框架5从4升级

时间:2012-11-07 17:06:21

标签: c# linq entity-framework-4 entity-framework-5

我在搜索中遇到了Where子句的问题,在我的原始版本EF4中,我可以添加一个带有2个参数的Where子句,where子句(字符串谓词)和ObjectParameter列表,例如

var query = context.entities.Where(WhereClause.ToString(), Params.ToArray());

因为我升级到EF5我似乎没有那个选项,我错过了什么?

这最初用于构建动态where子句,例如“it.entity_id = @entity_id”,然后在ObjectParameter中保存变量值。

我希望我不必重写所有以这种方式构建的搜索,所以非常感谢任何帮助。

干杯

1 个答案:

答案 0 :(得分:1)

为了将ESQL与DbContext一起使用,您必须“下拉”到ObjectContext。

var objectContext = ((IObjectContextAdapter)context).ObjectContext;
var query = objectContext.CreateQuery<MyEntity>(
    WhereClause.ToString(),
    Params.ToArray());