Chargement explicite de données connexes
Chargement explicite
Vous pouvez charger explicitement une propriété de navigation via l’API DbContext.Entry(...)
.
using (var context = new BloggingContext())
{
var blog = await context.Blogs
.SingleAsync(b => b.BlogId == 1);
await context.Entry(blog)
.Collection(b => b.Posts)
.LoadAsync();
await context.Entry(blog)
.Reference(b => b.Owner)
.LoadAsync();
}
Vous pouvez également explicitement charger une propriété de navigation en exécutant une requête distincte qui retourne les entités associées. Si le suivi des modifications est activé, lorsqu’une requête matérialise une entité, EF Core définit automatiquement les propriétés de navigation de l’entité qui vient d’être chargée pour faire référence à toutes les entités déjà chargées et définir les propriétés de navigation des entités déjà chargées pour faire référence à l’entité qui vient d’être chargée.
Interrogation des entités associées
Vous pouvez également obtenir une requête LINQ qui représente le contenu d’une propriété de navigation.
Cela vous permet d’appliquer d’autres opérateurs sur la requête. Par exemple, l’application d’un opérateur d’agrégation sur les entités associées sans les charger en mémoire.
using (var context = new BloggingContext())
{
var blog = await context.Blogs
.SingleAsync(b => b.BlogId == 1);
var postCount = await context.Entry(blog)
.Collection(b => b.Posts)
.Query()
.CountAsync();
}
Vous pouvez également filtrer les entités associées qui sont chargées en mémoire.
using (var context = new BloggingContext())
{
var blog = await context.Blogs
.SingleAsync(b => b.BlogId == 1);
var goodPosts = await context.Entry(blog)
.Collection(b => b.Posts)
.Query()
.Where(p => p.Rating > 3)
.ToListAsync();
}