using System.Collections.Generic;
using System.Diagnostics;
using System.Data.Entity;
using System.Data.Entity.Migrations;
public static List<BenchmarkResult> BenchmarkResults = new List<BenchmarkResult>();
public static void Main()
var clockSaveChanges = new Stopwatch();
var clockBulkSaveChanges = new Stopwatch();
var clockBulkSaveChangesFalse = new Stopwatch();
using (var context = new EntityContext())
context.BulkDelete(context.Customers);
GenerateCustomers(customerCount);
context.Customers.ToList().ForEach(x => x.FirstName += "_z");
var toAdd = new List<Customer>();
for(int i = 0; i < customerCount; i++)
toAdd.Add(new Customer() { Code = "Insert_Code_" + i, FirstName = "Insert_FirstName_" + i, LastName = "Insert_LastName_" + i });
context.Customers.AddRange(toAdd);
clockSaveChanges.Start();
BenchmarkResults.Add(new BenchmarkResult() { Action = "SaveChanges (EF)", Entities = context.Customers.Count(), Performance = clockSaveChanges.ElapsedMilliseconds + " ms" });
using (var context = new EntityContext())
context.BulkDelete(context.Customers);
GenerateCustomers(customerCount);
context.Customers.ToList().ForEach(x => x.FirstName += "_z");
var toAdd = new List<Customer>();
for(int i = 0; i < customerCount; i++)
toAdd.Add(new Customer() { Code = "Insert_Code_" + i, FirstName = "Insert_FirstName_" + i, LastName = "Insert_LastName_" + i });
context.Customers.AddRange(toAdd);
clockBulkSaveChanges.Start();
context.BulkSaveChanges();
clockBulkSaveChanges.Stop();
BenchmarkResults.Add(new BenchmarkResult() { Action = "BulkSaveChanges (EF Classic)", Entities = context.Customers.Count(), Performance = clockBulkSaveChanges.ElapsedMilliseconds + " ms" });
context.BulkDelete(context.Customers);
using (var context = new EntityContext())
context.BulkDelete(context.Customers);
GenerateCustomers(customerCount);
context.Customers.ToList().ForEach(x => x.FirstName += "_z");
var toAdd = new List<Customer>();
for(int i = 0; i < customerCount; i++)
toAdd.Add(new Customer() { Code = "Insert_Code_" + i, FirstName = "Insert_FirstName_" + i, LastName = "Insert_LastName_" + i });
context.Customers.AddRange(toAdd);
clockBulkSaveChangesFalse.Start();
context.BulkSaveChanges(false);
clockBulkSaveChangesFalse.Stop();
BenchmarkResults.Add(new BenchmarkResult() { Action = "BulkSaveChanges(false) (EF Classic)", Entities = context.Customers.Count(), Performance = clockBulkSaveChangesFalse.ElapsedMilliseconds + " ms" });
context.BulkDelete(context.Customers);
FiddleHelper.WriteTable(BenchmarkResults);
public static void JustInTime_Compile()
using (var context = new EntityContext())
context.Customers.ToList().ForEach(x => x.FirstName += "_z");
using (var context = new EntityContext())
context.Customers.ToList().ForEach(x => x.FirstName += "_z");
context.BulkSaveChanges();
using (var context = new EntityContext())
context.Customers.ToList().ForEach(x => x.FirstName += "_z");
context.BulkSaveChanges(false);
using (var context = new EntityContext())
context.BulkDelete(context.Customers);
public static List<Customer> GenerateCustomers(int count)
var list = new List<Customer>();
for(int i = 0; i < count; i++)
list.Add(new Customer() { Code = "Update_Code_" + i, FirstName = "Update_FirstName_" + i, LastName = "Update_LastName_" + i });
using (var context = new EntityContext())
context.BulkInsert(list);
public class EntityContext : DbContext
public EntityContext() : base(FiddleHelper.GetConnectionStringSqlServer())
public DbSet<Customer> Customers { get; set; }
public int CustomerID { get; set; }
public string Code { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public class BenchmarkResult
public string Action { get; set; }
public int Entities { get; set; }
public string Performance { get; set; }