using System.Collections.Generic;
using System.Diagnostics;
using System.Data.Entity;
using System.Threading.Tasks;
public static void Main()
public static async Task MainAsync()
var customers = SeedCustomer(5);
using (var context = new EntityContext())
FiddleHelper.WriteTable("1 - Customers Before ", context.Customers.AsNoTracking());
var toDelete = customers.Take(customers.Count() / 2);
CancellationTokenSource tcs = new CancellationTokenSource();
CancellationToken token = new CancellationToken();
await context.BulkDeleteAsync(toDelete, token);
FiddleHelper.WriteTable("2 - Customers After", context.Customers.AsNoTracking());
public static List<Customer> SeedCustomer(int count)
List<Customer> list = new List<Customer>();
for(int i = 0; i < count; i++)
list.Add(new Customer() { Name = "Customer_" + i});
new EntityContext().BulkInsert(list);
public class EntityContext : DbContext
public EntityContext() : base(FiddleHelper.GetConnectionStringSqlServer())
public DbSet<Customer> Customers { get; set; }
public int CustomerID { get; set; }
public string Name { get; set; }