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

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

Читать онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
1 ... 442 443 444 445 446 447 448 449 450 ... 642
Перейти на страницу:

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать

}

public void Dispose()

{

  Dispose(true);

  GC.SuppressFinalize(this);

}

private bool _isDisposed;

protected virtual void Dispose(bool disposing)

{

  if (_isDisposed)

  {

    return;

  }

  if (disposing)

  {

    if (_disposeContext)

    {

      Context.Dispose();

    }

  }

  _isDisposed = true;

}

~BaseRepo()

{

  Dispose(false);

}

На свойства DbSet<T> класса ApplicationDbContext можно ссылаться с использованием метода Context.Set<T>(). Создайте открытое свойство по имени Table типа DbSet<T> и установите его начальное значение в конструкторе:

public DbSet<T> Table { get; }

protected BaseRepo(ApplicationDbContext context)

{

  Context = context;

<b>  Table = Context.Set&lt;T&gt;();</b>

  _disposeContext = false;

}

Реализация метода SaveChanges()

Класс BaseRepo имеет метод SaveChanges(), который вызывает переопределенную версию SaveChanges() и демонстрирует обработку специальных исключений. Добавьте в класс BaseRepo показанный ниже код:

public int SaveChanges()

{

  try

  {

    return Context.SaveChanges();

  }

  catch (CustomException ex)

  {

    // Подлежит надлежащей обработке -- уже зарегистрировано в журнале.

    throw;

  }

  catch (Exception ex)

  {

    // Подлежит регистрации в журнале и надлежащей обработке.

    throw new CustomException(&quot;An error occurred updating the database&quot;, ex);

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

  }

}

Реализация общих методов чтения

Следующий комплект методов возвращает записи с применением операторов LINQ. Метод Find() принимает первичный ключ (ключи) и сначала выполняет поиск в ChangeTracker. Если сущность уже отслеживается, тогда возвращается отслеживаемый экземпляр, иначе запись извлекается из базы данных.

public virtual T? Find(int? id) =&gt; Table.Find(id);

Дополнительные два метода Find() расширяют базовый метод Find(). Приведенный далее метод демонстрирует извлечение записи, но без ее добавления в ChangeTracker, используя AsNoTrackingWithldentityResolution(). Добавьте в класс показанный ниже код:

public virtual T? FindAsNoTracking(int id) =&gt;

  Table.AsNoTrackingWithIdentityResolution().FirstOrDefault(x =&gt; x.Id == id);

Другая вариация удаляет из сущности фильтры запросов и затем применяет сокращенную версию (пропускающую метод Where()) для получения FirstOrDefault(). Добавьте в класс следующий код:

public T? FindIgnoreQueryFilters(int id) =&gt;

  Table.IgnoreQueryFilters().FirstOrDefault(x =&gt; x.Id == id);

Методы GetAll() возвращают все записи из таблицы. Первый метод извлекает их в порядке, поддерживаемом в базе данных, а второй по очереди обрабатывает все фильтры запросов:

public virtual IEnumerable&lt;T&gt; GetAll() =&gt; Table;

public virtual IEnumerable&lt;T&gt; GetAllIgnoreQueryFilters()

  =&gt; Table.IgnoreQueryFilters();

Метод ExecuteQuery() предназначен для выполнения хранимых процедур:

public void ExecuteQuery(string sql, object[] sqlParametersObjects)

  =&gt; Context.Database.ExecuteSqlRaw(sql, sqlParametersObjects);

Реализация методов добавления, обновления и удаления

Далее понадобится добавить блок кода, который будет служить оболочкой для соответствующих методов добавления, обновления и удаления, связанных со специфичным свойством DbSet&lt;T&gt;. Параметр persist определяет, выполняет ли хранилище вызов SaveChanges() сразу же после вызова методов добавления, обновления и удаления. Все методы помечены как virtual, чтобы сделать возможным дальнейшее переопределение. Добавьте в класс показанный ниже код:

1 ... 442 443 444 445 446 447 448 449 450 ... 642
Перейти на страницу:
Отывы о книге
Открыть боковую панель
Комментарии
Ксения
Ксения 25.01.2025 - 12:30
Неплохая подборка книг. Прочитаю все однозначно.
Jonna
Jonna 02.01.2025 - 01:03
Страстно🔥 очень страстно
Ксения
Ксения 20.12.2024 - 00:16
Через чур правильный герой. Поэтому и остался один
Настя
Настя 08.12.2024 - 03:18
Прочла с удовольствием. Необычный сюжет с замечательной концовкой
Марина
Марина 08.12.2024 - 02:13
Не могу понять, где продолжение... Очень интересная история, хочется прочесть далее