微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在父子关系中具有多个对象的Linq查询

如何解决在父子关系中具有多个对象的Linq查询

| 我有这样的架构 套餐->列表->用户 所有“一对多” ... 因此,我想运行一个查询,以获取用户ID相匹配的所有软件包。
var pck = (from pk in context.Package
             where pk.Lists[here\'s my problem]
我假设此处的导航属性为:“ 1”,但是我没有在“列表”级别看到导航属性。 我还没有像这样更复杂的EF查询。我环顾了网上,但没有找到任何可点击的东西。我转向你。有人帮我看光! 编辑:再次感谢堆栈,我将尽我所能支付它! 同样,所有这些答案使我对ef4的力量感到启发!     

解决方法

        我假设一个程序包包含多个列表,而一个列表包含多个用户?您可以尝试:
var pck = content.Package
     // Outdented just for Stack Overflow\'s width
     .Where(pk => pk.Lists.Any(list => list.Any(u => u.UserId == myUserId)));
或使用交叉联接:
var pck = from pk in content.Package
          from list in pk.Lists
          from user in list.Users
          where user.UserId == myUserId
          select ...; // Select whatever you\'re interested in
    ,        
context.Packages.Where(p => p.Lists.Any(l => l.Users.Contains(MyUserId)))
或者,如果您的用户是其他用户,而不仅仅是用户ID,
context.Packages.Where(p => p.Lists.Any(l => l.Users.Any(u => u.Id == MyUserId)))
    ,        
var packages =
    context.Package.Where(p =>
        p.Lists.Any(l => 
            l.Users.Any(u => u.UserId == MyUserId
        )
    );
    ,        如果链接是不可为空的,并且Direction是package包含许多列表,而list具有许多用户,则查询非常简单。
var pck = from user in context.Users
          where user.UserId == userId
          select user.List.Package;
    ,        尝试这个:
pk.Lists.Any(l => l.Users.Any(u => u.UserId == MyUserId))
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。