我正在尝试将以下 SQL 查询转换为 linq;
select Or.Amount, Usr.Name, Usr.Email
from [order] as Or
left join vw_AllUsers as Usr on Usr.UserId = Or.UserId and Usr.RoleName <> 'Admin'
我找不到在同一个连接中使用相等和不相等的方法。如果Usr.RoleName <> 'Admin'是Usr.RoleName = 'Admin',则 linq 语句可以这样写
var result = from Or in context.orders
join Usr in context.vw_AllUsers on
new { userid = Or.UserId, role = "Admin"}
equals
new { userid = Usr.UserId, role = Usr.RoleName}
select ........
或者我可以在 linq 的一部分中处理它以获得相同的结果,如下所示
where !Usr.RoleName.Equals("Admin")
但是可以在 linq 的连接部分中处理这个问题吗?
提前致谢