1

我有一组映射到我的数据库并正确填充的对象,但是当我需要根据孙对象的值返回一组对象时,我遇到了这种情况。这些对象之间的关系导致我无法成功创建此 linq 查询。

对象如下:

public class Pet
{
    public int PetID { get; set; }
    public string Name { get; set; }

    public virtual int ToyID { get; set; }
    public virtual Toy Toy { get; set; }
}

public class Toy
{
    public int ToyID { get; set; }
    public string Name { get; set; }

    public virtual ICollection<Owner> Owners { get; set; }
    public virtual ICollection<Pet> Pets { get; set; }
}

public class Owner
{
    public int OwnerID {get; set;}
    public string Name {get; set;}

    public virtual ICollection<Toy> Toys { get; set; }
}

所以基本上它是一对多对多的关系。

我有一个宠物集合,我想根据 Owner 对象的 Name 属性进行限制。

4

1 回答 1

5

那这个呢?

Pets.Where( p => p.Toy.Owners.Any(o => o.Name == "OwnerNameYourLookingFor") );

这将返回在其所有者列表中有 OwnerNameYourLookingFor 的 Pets 的可枚举。

于 2012-08-05T19:20:24.007 回答