Я использовал общий репозиторий и шаблоны 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);
}