Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
При работе с SQL Server доступен сокращенный метод, который можно использовать для включения
SqlServerRetryingExecutionStrategy
SqlServerOptions
EnableRetryOnFailure()
public ApplicationDbContext CreateDbContext(string[] args)
{
var optionsBuilder = new DbContextOptionsBuilder<ApplicationDbContext>();
var connectionString = @"server=.,5433;Database=AutoLot50;
User Id=sa;Password=P@ssw0rd;";
optionsBuilder.UseSqlServer(connectionString,
<b> options => options.EnableRetryOnFailure());</b>
return new ApplicationDbContext(optionsBuilder.Options);
Максимальное количество повторов и предельное время между повторами можно конфигурировать в зависимости от требований приложения. Если предел повторов достигается без завершения операции, тогда EF Core уведомит приложение о проблемах с подключением путем генерации
RetryLimitExceededException
try
{
Context.SaveChanges();
}
catch (RetryLimitExceededException ex)
{
// Превышен предел повторов.
// Требуется интеллектуальная обработка.
Console.WriteLine($"Retry limit exceeded! {ex.Message}");
}
Для поставщиков баз данных, которые не предлагают встроенной стратегии выполнения, можно создавать специальную стратегию выполнения. Дополнительные сведения ищите в документации по EF Core:
https://docs.microsoft.com/ru-ru/ef/core/miscellaneous/connection-resiliency
Связанные данные
Навигационные свойства сущности используются для загрузки связанных данных сущности. Связанные данные можно загружать энергичным образом (один оператор LINQ, один запрос SQL), энергичным образом с разделением запросов (один оператор LINQ, множество запросов SQL), явным образом (множество вызовов LINQ, множество запросов SQL) или ленивым образом (один оператор LINQ, множество запросов SQL по требованию).
Помимо возможности загрузки связанных данных с применением навигационных свойств исполняющая среда EF Core будет автоматически приводить в порядок сущности по мере их загрузки в
ChangeTracker
Make
DbSet<Make>
Car
DbSet<Car>
Энергичная загрузка
Энергичная загрузка — это термин для обозначения загрузки связанных записей из множества таблиц в рамках одного обращения к базе данных. Прием аналогичен созданию запроса в Т-SQL, связывающего две или большее число таблиц с помощью соединений. Когда сущности имеют навигационные свойства, которые используются в запросах LINQ, механизм трансляции применяет соединения, чтобы получить данные из связанных таблиц, и загружает соответствующие сущности. Такое решение обычно гораздо эффективнее, чем выполнение одного запроса с целью получения данных из одной таблицы и выполнение дополнительных запросов для каждой связанной таблицы. В ситуациях, когда использовать один запрос менее эффективно, в EF Core 5 предусмотрено разделение запросов, которое рассматривается далее.
Методы
Include()
ThenInclude()
Например, чтобы загрузить все записи
Car
Make
var queryable = Context.Cars.IgnoreQueryFilters().Include(
c => c.MakeNavigation).ToList();
Предыдущий запрос LINQ выполняет в отношении базы данных такой запрос:
SELECT [i].[Id], [i].[Color], [i].[MakeId], [i].[PetName], [i].[TimeStamp],
[m].[Id], [m].[Name], [m].[TimeStamp]
FROM [Dbo].[Inventory] AS [i]
INNER JOIN [dbo].[Makes] AS [m] ON [i].[MakeId] = [m].[Id]
В одном запросе можно использовать множество вызовов
Include()
ThenInclude()
Include()
Cars
Make
Order
Customer
Order
var cars = Context.Cars.Where(c => c.Orders.Any())
.Include(c => c.MakeNavigation)
.Include(c => c.Orders).ThenInclude(o => o.CustomerNavigation).ToList();
Фильтрованные включаемые данные
В версии EF Core 5 появилась возможность фильтрации и сортировки включаемых данных. Допустимыми операциями при навигации по коллекции являются
Where()
OrderBy()
OrderByDescending()
ThenBy()
ThenByDescending()
Skip()
Take()
Make
Car