using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using Microsoft.Data.SqlClient;
public static void Main()
DapperPlusManager.Entity<Order>()
.Identity(x => x.OrderID, true);
DapperPlusManager.Entity<OrderItem>()
.Identity(x => x.OrderItemID, true);
var connection = new SqlConnection(FiddleHelper.GetConnectionStringSqlServer());
connection.CreateTable<Order>();
connection.CreateTable<OrderItem>();
var newOrders = GetNewOrders();
connection.BulkInsert(newOrders).ThenBulkInsert(x => x.Items);
FiddleHelper.WriteTable("1 - Orders", connection.Query<Order>("SELECT * FROM [Order]"));
FiddleHelper.WriteTable("2 - OrderItems", connection.Query<OrderItem>("SELECT * FROM [OrderItem]"));
public static List<Order> GetNewOrders()
var orders = new List<Order>();
orders.Add(new Order() { State = "New", Items = new List<OrderItem>() {
new OrderItem() { ProductName = "Dapper Plus", Quantity = 9 },
new OrderItem() { ProductName = "C# Eval Expression", Quantity = 14 }
orders.Add(new Order() { State = "New", Items = new List<OrderItem>() {
new OrderItem() { ProductName = "Entity Framework Extensions", Quantity = 19 }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int OrderID { get; set; }
public string State { get; set; }
public List<OrderItem> Items { get; set; }
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int OrderItemID { get; set; }
public int OrderID { get; set; }
public string ProductName { get; set; }
public int Quantity { get; set; }