Каждая сущность предметной области внутри уровня доступа к данным AutoLot
AutoLot.Dal новый каталог по имени Repos, предназначенный для хранения всех классов.На заметку!
Не воспринимайте следующий раздел как буквальную интерпретацию паттерна проектирования "Хранилище". Если вас интересует исходный паттерн, который послужил мотивом для создания приведенной здесь версии, тогда почитайте о нем по ссылкеhttp://www.martinfowler.com/eaaCatalog/repository.html.Добавление базового интерфейса IRepo
Базовый интерфейс IRepo
AutoLot.Dal новый каталог по имени Repos и создайте в нем еще один каталог под названием Base. Поместите в каталог Repos\Base новый файл интерфейса по имени IRepo.cs. Обновите операторы using, как показано ниже:using System;
using System.Collections.Generic;
Так выглядит полный интерфейс:
namespace AutoLot.Dal.Repos.Base
{
public interface IRepo
{
int Add(T entity, bool persist = true);
int AddRange(IEnumerable
int Update(T entity, bool persist = true);
int UpdateRange(IEnumerable
int Delete(int id, byte[] timeStamp, bool persist = true);
int Delete(T entity, bool persist = true);
int DeleteRange(IEnumerable
T? Find(int? id);
T? FindAsNoTracking(int id);
T? FindIgnoreQueryFilters(int id);
IEnumerable
IEnumerable
void ExecuteQuery(string sql, object[] sqlParametersObjects);
int SaveChanges();
}
}
Добавление класса BaseRepo
Добавьте в каталог Repos\Base
BaseRepo.cs. Класс BaseRepo будет реализовывать интерфейс IRepo и предлагать основную функциональность для хранилищ, специфичных к типам (рассматриваются далее). Приведите операторы using к следующему виду:using System;
using System.Collections.Generic;
using System.Linq;
using AutoLot.Dal.EfStructures;
using AutoLot.Dal.Exceptions;
using AutoLot.Models.Entities.Base;
using Microsoft.EntityFrameworkCore;
Сделайте класс обобщенным с типом Т
BaseEntity и new(), что сузит набор типов до классов, которые имеют конструктор без параметров. Реализуйте интерфейс IRepo:public abstract class BaseRepo
Классу хранилища нужен экземпляр ApplicationDbContext
DbContextOptions и должен создавать экземпляр ApplicationDbContext, который понадобится освобождать. Поскольку этот класс является абстрактным, оба конструктора определяются как защищенные. Добавьте в открытый класс ApplicationDbContext следующий код:private readonly bool _disposeContext;
public ApplicationDbContext Context { get; }
protected BaseRepo(ApplicationDbContext context)
{
Context = context;
_disposeContext = false;
}
protected BaseRepo(DbContextOptions
ApplicationDbContext(options))
{
_disposeContext = true;
}
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
private bool _isDisposed;
protected virtual void Dispose(bool disposing)
{
if (_isDisposed)
{