J'ai une table auto-référencée nommée categories dont la colonne parentcategoryid est nullable. Lorsque j'ai ajouté la table au concepteur d'entité, elle a créé deux propriétés de navigation pour cette relation et j'ai nommé une ParentCategory (le prop 0 ou 1) et l'autre SubCategories (le * prop de plusieurs nav).Auto-référencement hiérarchique ADO Entité
Tout fonctionne très bien, sauf quand je vais plus d'un niveau de profondeur, il ne prend pas les niveaux les plus profonds.
Donc, je reçois toutes les catégories.SubCategories mais je ne reçois pas les catégories dans les sous-catégories.
Ai-je raté quelque chose? commencer à penser que je devrais avoir bloqué avec NHibernate. Les niveaux les plus profonds ne devraient-ils pas être paresseux?
return from c in _entities.ContentCategorySet.Include("SubCategories")
where c.ParentCategory == null
orderby c.Importance, c.Title
select c;
Je suppose que vous avez raison, je pensais qu'il devrait y avoir un peu de magie de l'entité, mais il y a je vais devoir les construire moi-même. – MvcCmsJon
J'ai déjà une méthode récursive. Le problème est que les autres catégories ne sont pas chargées dans l'entité. Vous dites que je dois aller chercher les nœuds les plus profonds pour construire l'entité? Je veux juste être sûr de comprendre. Il semble que ce devrait être quelque chose qui peut être paresseux chargé. – MvcCmsJon
Voici mon LINQ retour de c dans _entities.ContentCategorySet.Include ("") Sous-catégories où c.ParentCategory == null orderby c.Importance, c.Title select c; – MvcCmsJon