using Microsoft.EntityFrameworkCore;
using System.Collections.Generic;
using Microsoft.Data.SqlClient;
public static void Main()
using (var context = new EntityContext())
context.Database.EnsureCreated();
var customers = GenerateCustomers(3);
var invoices = GenerateInvoices(3, 3);
using (var context = new EntityContext())
FiddleHelper.WriteTable("1 - Customers Before", context.Customers.AsNoTracking());
FiddleHelper.WriteTable("2 - Invoices Before", context.Invoices.AsNoTracking());
FiddleHelper.WriteTable("3 - InvoiceItems Before", context.InvoiceItems.AsNoTracking());
context.BulkUpdate(customers);
context.BulkUpdate(invoices, options => options.IncludeGraph = true);
FiddleHelper.WriteTable("4 - Customers After", context.Customers.AsNoTracking());
FiddleHelper.WriteTable("5 - Invoices After", context.Invoices.AsNoTracking());
FiddleHelper.WriteTable("6 - InvoiceItems After", context.InvoiceItems.AsNoTracking());
public static List<Customer> GenerateCustomers(int count, bool useOld = false)
List<Customer> list = new List<Customer>();
for(int i = 0; i < count; i++)
list.Add(new Customer() { CustomerID = (i + 1), Name = (useOld ? "Old_" : "") + "Customer_" + i});
public static List<Invoice> GenerateInvoices(int countInvoice, int countInvoiceItem, bool useOld = false)
List<Invoice> list = new List<Invoice>();
for(int i = 0; i < countInvoice; i++)
var invoice = new Invoice() { InvoiceID = (i + 1), Number = (useOld ? "Old_" : "") + "Number_" + i, Items = new List<InvoiceItem>() };
for(int j = 0; j < countInvoiceItem; j++)
invoice.Items.Add(new InvoiceItem() { InvoiceItemID = (i * countInvoiceItem) + (j + 1), ProductName = (useOld ? "Old_" : "") + "ProductName_" + i + "_" + j });
public static void SeedCustomers(int count)
var customers = GenerateCustomers(count, true);
new EntityContext().BulkInsert(customers);
public static void SeedInvoices(int countInvoice, int countInvoiceItem)
var invoices = GenerateInvoices(countInvoice, countInvoiceItem, true);
new EntityContext().BulkInsert(invoices, options => options.IncludeGraph = true);
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 DbSet<Invoice> Invoices { get; set; }
public DbSet<InvoiceItem> InvoiceItems { get; set; }
public int CustomerID { get; set; }
public string Name { get; set; }
public int InvoiceID { get; set; }
public string Number { get; set; }
public List<InvoiceItem> Items { get; set; }
public int InvoiceItemID { get; set; }
public string ProductName { get; set; }
public Invoice Invoice { get; set; }