using System.Collections.Generic;
using System.Data.Entity;
public static void Main()
var customers = new List<Customer>();
for(int i = 0; i < 2; i++)
customers.Add(new Customer() { Code = "Code_" + i, FirstName = "Updated_FirstName_" + i, LastName = "Updated_LastName_" + i });
for(int i = 1000; i < 1002; i++)
customers.Add(new Customer() { Code = "Code_" + i, FirstName = "New_FirstName_" + i, LastName = "New_LastName_" + i});
x.CreatedDate = DateTime.Now;
x.ModifiedDate = DateTime.Now;
using(var context = new EntityContext())
FiddleHelper.WriteTable("1 - Before BulkMerge", context.Customers.AsNoTracking().ToList());
context.BulkMerge(customers, options => {
options.ColumnPrimaryKeyExpression = customer => customer.Code;
options.IgnoreOnMergeInsertExpression = customer => customer.ModifiedDate;
options.IgnoreOnMergeUpdateExpression = customer => customer.CreatedDate;
FiddleHelper.WriteTable("2 - After BulkMerge", context.Customers.AsNoTracking().ToList());
public static List<Customer> GenerateCustomers(int count)
var list = new List<Customer>();
for(int i = 0; i < count; i++)
list.Add(new Customer() { Code = "Code_" + i, FirstName = "FirstName_" + i, LastName = "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 DateTime? CreatedDate { get; set; }
public DateTime? ModifiedDate { get; set; }