Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/entity-framework/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在LINQ查询中从多个表设置条件?_Linq_Entity Framework_Entity Framework 4 - Fatal编程技术网

如何在LINQ查询中从多个表设置条件?

如何在LINQ查询中从多个表设置条件?,linq,entity-framework,entity-framework-4,Linq,Entity Framework,Entity Framework 4,在下面的查询中,我想返回满足多个条件的人。某些条件适用于包含要返回的人员的表中的字段。另一个条件应用于通过PersonId链接到主表(人员)的不同表(EmailAddresses) var t = People.Where(x => x.Type == 102 && x.FirstName == "Bob" && x.LastName == "Williams" &&

在下面的查询中,我想返回满足多个条件的人。某些条件适用于包含要返回的人员的表中的字段。另一个条件应用于通过PersonId链接到主表(人员)的不同表(EmailAddresses)

var t = People.Where(x =>
            x.Type == 102 &&
            x.FirstName == "Bob" &&
            x.LastName == "Williams" &&
                 x.EmailAddresses.Where (ea=> ea.EmailAddress
                                                 == "bob.williams@acme.org")
            )
            .Select(x => x.PersonId)

我该怎么做呢?

你明白这一点吗,至少其中一个应该有那个地址?如果是,请使用
Any
方法:

var t = People.Where(x =>
            x.Type == 102 &&
            x.FirstName == "Bob" &&
            x.LastName == "Williams" &&
                 x.EmailAddresses.Any(ea=> ea.EmailAddress
                                                 == "bob.williams@acme.org")
            )
            .Select(x => x.PersonId)

Any
如果
IQueryable
中至少有一个元素满足谓词,则返回true。

我认为可以通过连接来实现,类似这样的

var t = from p in People
        join e in EmailAddress on p.PersonId equals e.PersonId into pe
        from a in pe.DefaultIfEmpty
        where p.Type == 102 &&
           p.FirstName == "Bob" &&
           p.LastName == "Williams" &&
           a.EmailAddress == "bob.williams@acme.org"
        select p.PersonId

对的我想要返回的人必须符合所有四个条件。是的,这就是我得到的。问题是,
EmailAddresss
属性中必须匹配什么?只有一个电子邮件地址,对吗?如果是,这将工作。对不起,是的,应该只有一封电子邮件address@Femaref从技术上讲,当使用EF时,您不需要在IEnumerable上调用方法,而是在IQueryable上调用方法。不同之处在于,您的Any委托实际上不会执行,但在调用IQuerableyes时只会生成一个表达式树。但IQueryable也是一个IEnumerable;)