LINQ Lambda Left join with an Inner join

前端 未结 3 392
予麋鹿
予麋鹿 2021-01-21 12:13

I have written a LINQ lambda query which so far which returns all staff which do not have an associated training row which works fine. I now need to amend my where clause to use

相关标签:
3条回答
  • 2021-01-21 12:13

    Inner joins are performed with the Join method. I think your query should go something like this:

    var query = db.staff
                  .GroupJoin(db.training,
                             s => s.id,
                             t => t.staff_id,
                             (s, t) => new { Staff = s, Training = t.FirstOrDefault() })
                  .Join(db.manager,
                        gj => gj.Staff.manager_id,
                        m => m.id,
                        (gj, m) => new { Staff = gj.Staff, Training = gj.Training, Manager = m })
                  .Where(st => st.Training == null
                            && st.Manager.id == managerId);
    
    0 讨论(0)
  • 2021-01-21 12:18

    You can do the following (I've not used method chaining syntax to make it more readable IMO):

    var query = from s in db.staff
                join m in db.manager on s.manager_id equals m.id
                join t in db.training on s.id equals t.staff_id into tr
                from training in tr.DefaultIfEmpty()
                select new
                {
                    Staff = s,
                    Training = training
                };
    
    0 讨论(0)
  • 2021-01-21 12:28

    Like this maybe:

    var query = from s in db.staff
        join m in db.manager on s.manager_id equals m.id
        from t in db.training
            .Where(w=>w.staff_id==s.id).DefaultIfEmpty()
        select new
        {
            Staff = s,
            Training = training
        };
    
    0 讨论(0)
提交回复
热议问题