books-read.com
books-read.com » Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Наш ресурс дает возможность бесплатно читать книгу онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю. Жанр: Базы данных . Сайт books-read.com дает возможность читать полную версию книги без регистрации и sms. Все книги онлайн, не надо качать fb2, epub, txt.
Добавить книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю в приложение ЧИТАТЬ КНИГУ ОФЛАЙН в приложении ios/android
Перейти на страницу:

При работе с 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 =&gt; options.EnableRetryOnFailure());</b>

  return new ApplicationDbContext(optionsBuilder.Options);

Максимальное количество повторов и предельное время между повторами можно конфигурировать в зависимости от требований приложения. Если предел повторов достигается без завершения операции, тогда EF Core уведомит приложение о проблемах с подключением путем генерации

RetryLimitExceededException
. В случае обработки это исключение способно передавать необходимую информацию пользователю, обеспечивая лучший отклик:

try

{

  Context.SaveChanges();

}

catch (RetryLimitExceededException ex)

{

  // Превышен предел повторов.

  // Требуется интеллектуальная обработка.

  Console.WriteLine($&quot;Retry limit exceeded! {ex.Message}&quot;);

}

Для поставщиков баз данных, которые не предлагают встроенной стратегии выполнения, можно создавать специальную стратегию выполнения. Дополнительные сведения ищите в документации по 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&lt;Make&gt;
, после чего все записи
Car
загружаются в
DbSet&lt;Car&gt;
. Несмотря на то что записи загружались по отдельности, они будут доступны друг другу через навигационные свойства.

Энергичная загрузка

Энергичная загрузка — это термин для обозначения загрузки связанных записей из множества таблиц в рамках одного обращения к базе данных. Прием аналогичен созданию запроса в Т-SQL, связывающего две или большее число таблиц с помощью соединений. Когда сущности имеют навигационные свойства, которые используются в запросах LINQ, механизм трансляции применяет соединения, чтобы получить данные из связанных таблиц, и загружает соответствующие сущности. Такое решение обычно гораздо эффективнее, чем выполнение одного запроса с целью получения данных из одной таблицы и выполнение дополнительных запросов для каждой связанной таблицы. В ситуациях, когда использовать один запрос менее эффективно, в EF Core 5 предусмотрено разделение запросов, которое рассматривается далее.

Методы

Include()
и
ThenInclude()
(для последующих навигационных свойств) применяются для обхода навигационных свойств в запросах LINQ. Если отношение является обязательным, тогда механизм трансляции LINQ создаст внутреннее соединение. Если же отношение необязательное, то механизм трансляции создаст левое соединение.

Например, чтобы загрузить все записи

Car
со связанной информацией
Make
, запустите следующий запрос LINQ:

var queryable = Context.Cars.IgnoreQueryFilters().Include(

  c =&gt; 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 =&gt; c.Orders.Any())

  .Include(c =&gt; c.MakeNavigation)

  .Include(c =&gt; c.Orders).ThenInclude(o =&gt; o.CustomerNavigation).ToList();

Фильтрованные включаемые данные

В версии EF Core 5 появилась возможность фильтрации и сортировки включаемых данных. Допустимыми операциями при навигации по коллекции являются

Where()
,
OrderBy()
,
OrderByDescending()
,
ThenBy()
,
ThenByDescending()
,
Skip()
и
Take()
. Например, если нужно получить все записи
Make
, но только со связанными записями
Car
с желтым цветом, тогда вы организуете фильтрацию навигационного свойства в лямбда-выражении такого вида:

Перейти на страницу:

Троелсен Эндрю читать все книги автора по порядку

Троелсен Эндрю - на сайте онлайн книг books-read.com Вы можете читать полные версии книг автора в одном месте.


Язык программирования C#9 и платформа .NET5 отзывы

Отзывы читателей о книге Язык программирования C#9 и платформа .NET5, автор: Троелсен Эндрю. Читайте комментарии и мнения людей о произведении.


Уважаемые читатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.

  • 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
  • 2. Просьба отказаться от оскорблений, угроз и запугиваний.
  • 3. Просьба отказаться от нецензурной лексики.
  • 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.

Надеемся на Ваше понимание и благоразумие. С уважением, администратор books-read.com


Прокомментировать
Подтвердите что вы не робот:*