using System.Data.Entity;
using Z.EntityFramework.Classic;
public static void Main()
using (var context = new EntityContext())
context.FilterISoftDelete.Disable();
var list = context.Customers.ToList();
FiddleHelper.WriteTable("QueryResultFilter.Disable()", list);
using (var context = new EntityContext())
context.FilterISoftDelete.Enable();
var list = context.Customers.ToList();
FiddleHelper.WriteTable("QueryResultFilter.Enable()", list);
public static void GenerateData()
using (var context = new EntityContext())
context.Customers.Add(new Customer() { Name = "Customer_A", Description = "Description" });
context.Customers.Add(new Customer() { Name = "Customer_B", Description = "Description", IsDeleted = true });
context.Customers.Add(new Customer() { Name = "Customer_C", Description = "Description" });
public class EntityContext : DbContext
public QueryResultFilter FilterISoftDelete {get;set;}
public EntityContext() : base(FiddleHelper.GetConnectionStringSqlServer())
FilterISoftDelete = this.Configuration.QueryResultFilter.Filter<ISoftDelete>(customer => !customer.IsDeleted || this.DisplaySoftDelete());
public bool DisplaySoftDelete()
public DbSet<Customer> Customers { get; set; }
public interface ISoftDelete
bool IsDeleted { get; set; }
public class Customer : ISoftDelete
public int CustomerID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public bool IsDeleted { get; set; }