Как использовать мягкое удаление во включаемом свойстве универсального репозитория (Entity Framework)? - PullRequest
0 голосов
/ 19 октября 2019

Я использовал общий репозиторий и шаблоны UnitOfWork в своем проекте, и он хорошо работает.

Я решил изменить свой проект с помощью концепции мягкого удаления. Все хорошо, но в общем репозитории IncludesProperty он вернул все записи, состоящие из мягко удаленных записей!

Как вы видите ниже, я не знаю, как мне изменить

query = query.Include(includeProperty)

илилюбая строка моего кода, которую следует игнорировать в записях «Включить», помеченных

IsDeleted == true

Вот мой репозиторий:

 public virtual TEntity GetFirstBy(
        Expression<Func<TEntity, bool>> filter = null,
        Func<IQueryable<TEntity>, IOrderedQueryable<TEntity>> orderBy = null,
        string includeProperties = "")
    {
        IQueryable<TEntity> query = dbSet.Where(e => e.IsDeleted == false);

        if (filter != null)
        {
            query = query.Where(filter);
        }

        foreach (var includeProperty in includeProperties.Split
            (new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries))
        {
            query = query.Include(includeProperty); /// this line was first section that I changed to query.Include(includeProperty).Where(q => q.IsDeleted == false); but doesn't work!
        }

        if (orderBy != null)
        {
            // orderBy(query);
            query = orderBy(query);
        }

        return query.FirstOrDefault();
    }

    public IEnumerable<TEntity> GetAll()
    {
        return dbSet.AsEnumerable().Where(e => e.IsDeleted == false);
    }

    public virtual TEntity GetByID(long id)
    {
        // return dbSet.Find(id).Where(e => e.IsDeleted == false);
        return context.Set<TEntity>().Where(e => e.IsDeleted == false).SingleOrDefault(e => e.Id == id);
    }

    public virtual void Insert(TEntity entity)
    {
        entity.CreatedTime = DateTime.Now;
        entity.IsDeleted = false;
        dbSet.Add(entity);
    }

1 Ответ

0 голосов
/ 19 октября 2019

Как сказал @David, я меняю способ мягкого удаления и использую Глобальные фильтры запросов в OnModelCreating.

modelBuilder.Entity (). HasQueryFilter (p =>! p.IsDeleted);

Он автоматически применяется к любым запросам LINQ, связанным с этими типами объектов, включая типы объектов, на которые ссылаются косвенно, например, путем использования ссылок на свойства Include или direct.

если я решу просто игнорировать софт-удаление по какой-либо временной причине, я использую IgnoreQueryFilters, как показано ниже

blogs = db.Blogs
.Include(b => b.Posts)
.IgnoreQueryFilters()
.ToList()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...