如何使用内部联接和子查询将SQL查询转换为LINQ lambda表达式

时间:2019-09-22 08:52:16

标签: sql linq

我想将以下SQL查询转换为LINQ lambda表达式。

SELECT Hod.* 
FROM (SELECT * FROM tbLease_Approval
      WHERE (UserRole='HOD' and IsApproved=1)) Pm 
INNER JOIN (SELECT * FROM tbLease_Approval
            WHERE UserRole='Finance' and IsApproved=0) Hod 
ON Pm.LeaseNo=Hod.LeaseNo

1 个答案:

答案 0 :(得分:0)

我还没有测试过,但是应该是这样的:

var qry= tbLease_Approval
             .Join(tbLease_Approval, hod => hod.LeaseNo, fin => fin.LeaseNo, (hod, fin) => new { Hod = hod, Finance = fin })
             .Where(joined => joined.Hod.UserRole.Equals("Hod")
                           && joined.Hod.IsApproved == 1
                           && joined.Finance.UserRole.Equals("Finance")
                           && joined.Finance.IsApproved == 0);
相关问题