Это нормально, выдает левое соединение
var q =
from c in categories
join p in products
on c equals p.Category into ps
from p in ps.DefaultIfEmpty()
select new { Category = c, ProductName = p == null ? "(No products)" : p.ProductName };
Но что если я захочу сделать что-то вроде этого:
...
on p.date between c.startdate and c.enddate
...