var connectionString = @"server=.,5433;Database=AutoLot50;
User Id=sa;Password=P@ssw0rd;";
optionsBuilder.UseSqlServer(connectionString,
options => options.EnableRetryOnFailure());
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, после чего все записи Car загружаются в DbSet. Несмотря на то что записи загружались по отдельности, они будут доступны друг другу через навигационные свойства.Энергичная загрузка
Методы Include()
ThenInclude() (для последующих навигационных свойств) применяются для обхода навигационных свойств в запросах LINQ. Если отношение является обязательным, тогда механизм трансляции LINQ создаст внутреннее соединение. Если же отношение необязательное, то механизм трансляции создаст левое соединение.Например, чтобы загрузить все записи Car
Make, запустите следующий запрос LINQ: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())