using Microsoft.EntityFrameworkCore;
using System.Collections.Generic;
using Microsoft.Data.SqlClient;
public static void Main()
using (var context = new EntityContext())
context.Database.EnsureCreated();
var customizeToSynchronize = new List<Customer>();
for(int i = 0; i < 2; i++)
customizeToSynchronize.Add(new Customer() { Code = "Code_" + i, FirstName = "Updated_FirstName_" + i, LastName = "Updated_LastName_" + i, CreatedDate = DateTime.Now, UpdatedDate = DateTime.Now });
for(int i = 0; i < 2; i++)
customizeToSynchronize.Add(new Customer() { Code = "New_Code_" + i, FirstName = "New_FirstName_" + i, LastName = "New_LastName_" + i, CreatedDate = DateTime.Now, UpdatedDate = DateTime.Now });
using (var context = new EntityContext())
FiddleHelper.WriteTable("1 - Customers Before", context.Customers.AsNoTracking());
context.BulkSynchronize(customizeToSynchronize, options => {
options.ColumnPrimaryKeyExpression = c => c.Code;
options.IgnoreOnSynchronizeInsertExpression = c => c.UpdatedDate;
options.IgnoreOnSynchronizeUpdateExpression = c => c.CreatedDate;
FiddleHelper.WriteTable("2 - Customers After", context.Customers.AsNoTracking());
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, CreatedDate = DateTime.Now.AddDays(-2) });
using (var context = new EntityContext())
context.BulkInsert(list);
public class EntityContext : DbContext
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
optionsBuilder.UseSqlServer(new SqlConnection(FiddleHelper.GetConnectionStringSqlServer()));
base.OnConfiguring(optionsBuilder);
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? UpdatedDate { get; set; }