Błąd łączenia LINQ Lambda - nie można wywnioskować z użycia

Miałem problemy z dołączeniem do dwóch DbSets i nadal otrzymywałem „nie można wywnioskować błędu”. Usiłowałem znaleźć rozwiązanie, więc pomyślałem, że podzielę się moją prostą odpowiedzią. Jest kilka świetnych postów od Jona Skeeta i innych, ale większość odpowiedzi była nad moją głową.

Oto kod, który sprawiał mi kłopoty:

using(var db = new SomeDataContext())
    {
    db.DemandData
        .Where(demand=> demand.ID == SearchID)
        .Join(db.CUST_ORDER_LINE,
            supply=> new { supply.LINE, supply.SALES_ORDER_ID },
            demand=> new { demand.LINE_NO, demand.CUST_ORDER_ID },
            (supply, demand) => new { custOrderLineReturn = demand })
        .Select(s => s.custOrderLineReturn )
        .ToList();
    }

questionAnswers(1)

yourAnswerToTheQuestion