je recevais des lignes de répéter cette requête LINQ:Linq bizarrerie
public static Func<DataContext, string, IQueryable<Building>>
GearFilteredBuildings =
CompiledQuery.Compile((DataContext db, string filter) =>
from b in db.Building
join r in db.Router on b equals r.Building
orderby !b.Active
where filter.Length == 5 && r.Name.Substring(1, 5).ToLower() == filter
|| filter.Substring(0, 3) == r.Name.Substring(3, 3).ToLower()
select b);
Après quelques tripoter, je suis les bâtiments distincts avec ce:
public static Func<DataContext, string, IQueryable<Building>>
GearFilteredBuildings =
CompiledQuery.Compile((DataContext db, string filter) =>
(from b in db.Building
join r in db.Router on b equals r.Building
orderby !b.Active
where filter.Length == 5 && r.Name.Substring(1, 5).ToLower() == filter
|| filter.Substring(0, 3) == r.Name.Substring(3, 3).ToLower()
group b by b.Id into g
select g) as IQueryable<Building>);
Est-ce une solution acceptable? Sinon, comment cela pourrait-il être fait?
Si vous adhérez, vous verrez la duplication des lignes de parents en cas de plusieurs lignes enfants. C'est juste comment fonctionne la jointure. Ce n'est pas "étrange" du tout. –