我在搜索中遇到了Where子句的问题,在我的原始版本EF4中,我可以添加一个带有2个参数的Where子句,where子句(字符串谓词)和ObjectParameter列表,例如
var query = context.entities.Where(WhereClause.ToString(), Params.ToArray());
因为我升级到EF5我似乎没有那个选项,我错过了什么?
这最初用于构建动态where子句,例如“it.entity_id = @entity_id”,然后在ObjectParameter中保存变量值。
我希望我不必重写所有以这种方式构建的搜索,所以非常感谢任何帮助。
干杯
答案 0 :(得分:1)
为了将ESQL与DbContext一起使用,您必须“下拉”到ObjectContext。
var objectContext = ((IObjectContextAdapter)context).ObjectContext;
var query = objectContext.CreateQuery<MyEntity>(
WhereClause.ToString(),
Params.ToArray());