0

ユーザーデータを含むテーブルがあります

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

そして、次を含む別のテーブルがあります:

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

UserFriends テーブルには、このテーブルをユーザー テーブルと結合する 2 つの外部キーがあります。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
                };
4

2 に答える 2

0
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
               };
于 2013-08-28T09:41:53.757 に答える
0

テーブルには2つの外部キーがあるため、代わりにテーブルUsersを結合する必要がありますUsersUsersFriends

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)
            };
于 2013-08-28T06:08:37.363 に答える