繁体   English   中英

用两个外键联接两个表

[英]join two table with two foreign Key

我有一个包含用户数据的表

Users(userID, name , email ,......)

我还有另一个包含以下内容的表:

Userfriends(UserFriendID,Fk_UserSendReqID,FK_UserRecieveReqID,IsAccepted,....)

在UserFriends表中,有两个外键将这个表与users表连接起来,我想用linq编写查询,该查询选择userId=2的用户的朋友,但是我写了这个查询,但这是错误的

 var n = from u in DataContext.Context.Users
                join uf in DataContext.Context.UsersFriends
                on u.UserID equals uf.UserSendReqID
                join uf2 in DataContext.Context.UsersFriends
                on u.UserID equals uf2.UserRecieveReqID
                where (uf.UserSendReqID == 2|| uf.UserRecieveReqID == 2)
                && uf.IsAccepted == true
                select new
                {
                    name = u.FirstName + " " + u.LastName
                };

由于Users表有2个外键,因此您必须加入Users表而不是UsersFriends

var userID = 2;
var n = from u in DataContext.Context.Users
            join uf in DataContext.Context.UsersFriends
            on u.UserID equals uf.UserSendReqID
            join u in DataContext.Context.Users
            on u2.UserID equals uf.UserRecieveReqID
            where (uf.UserSendReqID == userID || uf.UserRecieveReqID == userID)
            && uf.IsAccepted == true
            select new
            {
                //if UserSendReqID == userID, then select for u, else u2
                name = (uf.UserSendReqID == userID)
                             ? (u.FirstName + " " + u.LastName)
                             : (u2.FirstName + " " + u2.LastName)
            };
var n = DataContext.Context.Users
                   .Where(u=>DataContext.Context.UsersFriends
                            .Where(uf=>(uf.UserSendReqID == 2 ||
                                       uf.UserReceiveReqID == 2) && uf.IsAccepted)
                            .Any(uf=>uf.UserFriendID == u.userID))
                   .Select(u=> new {
                                 Name = u.FirstName + " " + u.LastName                                     
                               });

或使用Join

var n = DataContext.Context.Users
                   .Join(DataContext.Context.UsersFriends
                                    .Where(uf=>(uf.UserSendReqID == 2 ||
                                       uf.UserReceiveReqID == 2) && uf.IsAccepted),
                         x=>x.userID, x=>x.UserFriendID, (x,y)=>x)
                   .Select(u=> new {
                                 Name = u.FirstName + " " + u.LastName                                     
                               });

表达式查询:

var n = from u in DataContext.Context.Users
        join uf in DataContext.Context.UsersFriends on u.userID equals uf.UserFriendID
        where (uf.UserSendReqID == 2 || uf.UserReceiveReqID == 2) && uf.IsAccepted
        select new {
                 Name = u.FirstName + " " + u.LastName
               };

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM