5

我有两个实体,用户和友谊,它们看起来像:

    public class User
    {
        public int UserId { get; set; }
        (...)
    }

    public class Friendship
    {
         public int SenderId { get; set; }
         public int ReceiverId { get; set; }
         (...)
    }

我想创建简单的查询,在 SQL 中看起来像:

    SELECT * FROM Users as U
    INNER JOIN Friendships as F ON U.UserId = F.ReceiverId OR U.UserId = F.SenderId
    Where U.Nick != VARIABLE

换句话说,我想选择用户的所有朋友。

而我无法做到这一点。我找到了一个解决方案,其中一个使用联合创建两个单独的连接查询并且它可以工作 - 但是为数据库创建这样的查询效率不高。

4

2 回答 2

4

LINQ 中的连接总是等值连接。基本上你需要多个from子句和一个where子句:

var query = from u in db.Users
            where u.Nick != variable
            from f in db.Friendships
            where u.UserId == f.ReceiveId || u.UserId == f.SenderId
            select ...;

现在在 LINQ to Objects 中可能有更有效的方法来执行此操作 - 但我希望基于 SQL 的 LINQ 提供程序能够生成具有足够好的执行计划的查询。它实际上可能不会在 SQL 中创建 JOIN,但我希望它与您显示的连接具有相同的执行计划。

于 2012-09-26T21:13:51.700 回答
1

简单地写:

from U in db.Users
from F in Friendships.Where(x => U.UserId == F.ReceiverId || U.UserId == F.SenderId)
where U.Nick != VARIABLE
select new {u, f};
于 2012-09-26T21:15:36.080 回答