首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Linq to entities

Linq to entities
EN

Stack Overflow用户
提问于 2009-08-07 16:19:14
回答 2查看 87关注 0票数 0

我想知道如何与EF1.0中的in数组进行比较

我知道在EF4.0Beta 1中有一个包含方法,所以它看起来像这样

代码语言:javascript
复制
int[] associationIds = GetAssociationIds();
from c in Associations where c.AssociationId.Contains(associationIds) select c;

但是如何在EF1.0中实现相同的功能呢?

EN

回答 2

Stack Overflow用户

发布于 2009-08-07 16:24:08

在EF1中没有内置的方法可以做到这一点。执行此任务最常用的工具是PredicateBuilder

解决方案(使用该工具包)是构建一个自定义表达式,根据整数数组中的每个ids测试AssociationId。生成的表达式如下所示:

代码语言:javascript
复制
int[] associationIds = GetAssociationIds();

// use PredicateBuilder to build this expression using the contents of
// associationIds:

Expression<Func<Association, bool>> testIds = 
    c => c.AssociationId == 1 || c.AssociationId == 2 || c.AssociationId == 5;

并使用它:

代码语言:javascript
复制
var matchingAssociations = db.Associations.Where(testIds);
票数 1
EN

Stack Overflow用户

发布于 2009-08-07 16:45:41

predicatebuilder文档列出了一种不使用linqkit的方法,所以我使用了该方法,它不是很好,但它可以在EF4.0出现之前完成这项工作。干杯

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1245688

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档