简体   繁体   English

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

[英]How to convert SQL query to LINQ lambda expression with Inner Join and subquery

I want to convert following SQL query into LINQ lambda expression.我想将以下 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

I have not tested this, but it should be something like:我没有测试过这个,但它应该是这样的:

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);

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

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