Таблица Linq to Entity Join с несколькими условиями ИЛИ

Мне нужно написать состояние Linq-Entity, которое может получить запрос SQL ниже

SELECT  RR.OrderId
FROM    dbo.TableOne RR
        JOIN dbo.TableTwo  M ON RR.OrderedProductId = M.ProductID OR RR.SoldProductId= M.ProductID
WHERE   RR.StatusID IN ( 1, 4, 5, 6, 7 )

Я застрял с синтаксисом ниже

 int[] statusIds = new int[] { 1, 4, 5, 6, 7 };
            using (Entities context = new Entities())
            {
                var query = (from RR in context.TableOne
                             join M in context.TableTwo on new { RR.OrderedProductId, RR.SoldProductId} equals new { M.ProductID }
                             where RR.CustomerID == CustomerID 
                             && statusIds.Any(x => x.Equals(RR.StatusID.Value))
                             select RR.OrderId).ToArray();
            }

это дает мне ошибку ниже

Ошибка 50 Неверный тип одного из выражений в предложении соединения. Ошибка вывода типа при вызове «Join».

Как я могу сделать соединение нескольких условий для таблицы.

Ответы на вопрос(3)

Ваш ответ на вопрос