La pagination est un aspect crucial du développement d'applications, en particulier lorsqu'il s'agit de grands ensembles de données. Entity Framework (EF) Core 8 en C# fournit des fonctionnalités puissantes pour implémenter une pagination efficace. Dans ce guide, nous explorerons les meilleures pratiques pour implémenter la pagination à l’aide d’EF Core 8, ainsi que des exemples.
EF Core fournit les méthodes Skip et Take, qui sont essentielles pour implémenter efficacement la pagination. Skip vous permet de sauter un nombre spécifié de lignes et Take limite le nombre de lignes renvoyées.
var pageNumber = 1; var pageSize = 10; var result = dbContext.YourEntity .OrderBy(e => e.SortingProperty) .Skip((pageNumber - 1) * pageSize) .Take(pageSize) .ToList();
Dans cet exemple, pageNumber et pageSize déterminent respectivement la page actuelle et le nombre d'éléments par page.
Pour les opérations en lecture seule telles que la récupération de données à des fins d'affichage, envisagez d'utiliser AsNoTracking pour améliorer les performances en évitant la surcharge liée au suivi des modifications.
var result = dbContext.YourEntity .AsNoTracking() .OrderBy(e => e.SortingProperty) .Skip((pageNumber - 1) * pageSize) .Take(pageSize) .ToList();
Ceci est particulièrement utile lorsque vous n'avez pas l'intention de mettre à jour ou d'enregistrer les modifications apportées aux entités récupérées.
Assurez-vous que les colonnes utilisées pour le tri sont indexées. Les colonnes indexées améliorent considérablement les performances des opérations de tri.
// Ensure SortingProperty is indexed modelBuilder.Entity<YourEntity>() .HasIndex(e => e.SortingProperty);
Les colonnes efficacement indexées accéléreront le tri et amélioreront les performances globales de pagination.
Pour déterminer le nombre total d'enregistrements sans récupérer toutes les données, utilisez Count avant d'appliquer la pagination. Cela évite de charger des données inutiles.
var totalRecords = dbContext.YourEntity.Count(); var result = dbContext.YourEntity .OrderBy(e => e.SortingProperty) .Skip((pageNumber - 1) * pageSize) .Take(pageSize) .ToList();
Soyez prudent lorsque vous utilisez Skip et Take pour la pagination dans des scénarios où les données peuvent être modifiées simultanément. Dans de tels cas, envisagez d'utiliser des méthodes alternatives telles que la pagination des jeux de clés pour une meilleure cohérence.
La mise en œuvre efficace de la pagination est cruciale pour améliorer les performances des applications traitant de grands ensembles de données. En suivant ces bonnes pratiques, vous pouvez vous assurer que votre logique de pagination est optimisée et évolutive lorsque vous utilisez EF Core 8 en C#.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!