Опитайте това вместо това
Query.ElemMatch("Children", Query.And(Query.EQ("StatusId",1), Query.EQ("Active",true),Query.LT("SubChild.ExpiresOn",DateTime.UtcNow)));
Чудите се защо тази заявка работи магически? Това е така (StatusId
срещу StatusID
). JavaScript е чувствителен към малки и големи букви.
Можете да премахнете този проблем, като използвате строго въведени Linq заявки, като:
from x in collection.AsQueryable()
where x.Children.Any(child =>
child.StatusId == 1
&& child.Active
&& child.SubChild.ExpiresOn < DateTime.UtcNow)
select x