Я хочу преобразовать этот sql-запрос в linq:
select * from A a
join B b on ( (a.level1= b.PerimeterID and b.PerimeterLevelID = 1)
OR (a.level2= b.PerimeterID and b.PerimeterLevelID = 2)
OR (a.level3= b.PerimeterID and b.PerimeterLevelID = 3)
)
Что я пробовал:
from a in A
join b in B on new {PerimeterID = a.level1, PerimeterLevelID = 1 } equals new { b.PerimeterID, b.PerimeterLevelID }
where (a.level2 == b.PerimeterID && b.PerimeterLevelID == 2) ||
(a.level3 == b.PerimeterID && b.PerimeterLevelID == 3)
генерирует этот SQL-запрос:
select * from A a
join B b on (a.level1= b.PerimeterID and b.PerimeterLevelID = 1)
where (a.level2= b.PerimeterID and b.PerimeterLevelID = 2)
OR (a.level3= b.PerimeterID and b.PerimeterLevelID = 3))
Я также пытался Linqer , но он не может преобразовать ИЛИ в linq
SQL не может быть преобразован в LINQ: ИЛИ
что мне нужно сделать, чтобы преобразовать этот SQL-запрос