Ce n'est pas une réponse complète pour vous, mais sur la pièce de jointure de gauche, vous pouvez utiliser l'opérateur DefaultIfEmpty comme ceci :
var collection =
from u in db.Universe
join history in db.History on u.id = history.id into temp
from h in temp.DefaultIfEmpty()
where h.dateCol < DateTime.Now.Date.AddDays(-1)
select u.id, u.name, h.dateCol ?? '1900-01-01'
Je n'ai pas encore eu besoin de faire de commandes groupby, donc j'ai laissé cela de côté pour ne pas vous envoyer sur le mauvais chemin. Deux autres choses rapides à noter. Je n'ai pas pu joindre réellement deux paramètres bien que, comme ci-dessus, il existe des moyens de le contourner. Également ?? L'opérateur fonctionne très bien à la place de isnull dans SQL.