SlideShare a Scribd company logo
Review of micro ORM in C#
Kanstantsin Harbachou
Agenda
• Intro into micro ORM
• PetaPoco/Massive
• Dapper
• SqlFu
• TinyORM
• Performance Comparison
• Example
Intro into micro ORM
• Mapper between objects and database queries
• Lightweight
• Fast
• Usually any powerful features are absent (UoW,
Lazy Loading, change tracking, etc.)
• Forget about domain model
When to use?
• Small number of queries
• Thin communication interface
• Utility applications
PetaPoco/Massive
1. Fluent configuration of mapping and connection string
2. Includes T4 templates to automatically generate POCO
classes
3. Not async
4. Tiny
5. Grabbing named parameters from object properties
Dapper
1.Multi mapping
2.Two kinds of mapping
3.Async
4.Extensions
5.Execute a Command multiple times
6.Buffered vs Unbuffered readers
SqlFu
1..NET Framework 4.6
2.CoreClr support
3.Async
4.Extensions
5.DDL tools
TinyORM
1.Helpers for CUD
2.Transactions
3.Task-based async API
4.POCOs
5.Snapshots
DataBase
Data
People – 2.000.000 records
Departments – 2.000.000 records
Work statuses – 4
People – Department and People – Status random
Queries and stored procedures
CRUD – 1000 entities
Stored procedure
Queries
Create
0
100
200
300
400
500
600
700
800
900
Dapper PetaPoco SqlFu Tiny
Create
Read
0
10000
20000
30000
40000
50000
60000
70000
80000
Dapper PetaPoco SqlFu Tiny
Read
Update
0
100
200
300
400
500
600
700
Dapper PetaPoco SqlFu Tiny
Update
Delete
145000
150000
155000
160000
165000
170000
175000
180000
185000
190000
Dapper PetaPoco SqlFu Tiny
Delete
Get people with name
52600
52700
52800
52900
53000
53100
53200
53300
53400
Dapper PetaPoco SqlFu Tiny
People with name
Count of people from current
department
26400
26600
26800
27000
27200
27400
27600
27800
28000
28200
28400
28600
People from department
All people from current
department with current status
56000
58000
60000
62000
64000
66000
68000
70000
72000
People with status
Example
public class Department
{
[Column(Name = "DepartmentId")]
public int Id { get; set; }
[Column(Name = "Nm")]
public string Name { get; set; }
[Column(Name = "Desc")]
public string Description { get; set; }
[Column(Name = "DptLeadId")]
public int DepartmentLeadId { get; set; }
}
Example
public T ExecuteStoredProcedure(string dataBase, object parameters)
{
var connection = new SqlConnection(ConfigurationManager.ConnectionStrings[dataBase].ConnectionString);
SqlMapper.SetTypeMap(typeof(T), new ColumnAttributeTypeMapper<T>());
var result = connection.QueryAsync<T>(ProcedureName, param: parameters,
commandType: CommandType.StoredProcedure).Result.FirstOrDefault();
return result;
}
public List<T> ExecuteStoredProcedureWithListResult(string dataBase, object parameters)
{
var connection = new SqlConnection(ConfigurationManager.ConnectionStrings[dataBase].ConnectionString);
SqlMapper.SetTypeMap(typeof(T), new ColumnAttributeTypeMapper<T>());
var result = connection.QueryAsync<T>(ProcedureName, param: parameters,
commandType: CommandType.StoredProcedure).Result.ToList();
return result;
}

More Related Content

PPTX
Beginner's Guide to NuPIC
PPTX
Strings, C# and Unmanaged Memory
PPTX
Hands on Performance Tuning - Mike Croft
PPTX
Hands-on Performance Workshop - The science of performance
PDF
Presto in my_use_case2
PPTX
Boost on!!next generation big data platform
PDF
Prometheus london
PDF
Rethinking Component Libraries
Beginner's Guide to NuPIC
Strings, C# and Unmanaged Memory
Hands on Performance Tuning - Mike Croft
Hands-on Performance Workshop - The science of performance
Presto in my_use_case2
Boost on!!next generation big data platform
Prometheus london
Rethinking Component Libraries

Similar to Review of micro Orm in c# (20)

PPTX
Micro ORM vs Entity Framework
PPTX
Orms vs Micro-ORMs
PPTX
Dapper: the microORM that will change your life
PPTX
refORM: Death to ORMs in .NET
PPTX
Advanced .NET Data Access with Dapper
PPTX
Dapper - Rise of the MicroORM
PDF
How To Do Excel-Like Row Selection in jQuery DataTable?
PPTX
Advanced data access with Dapper
PPTX
ORMs Meet SQL
PDF
Object Relational Mapping with Dapper (Micro ORM)
PDF
Entity Framework Interview Questions PDF By ScholarHat
PDF
Orm loveandhate
PPTX
PDF
Green dao
PPTX
Microsoft Data Access Technologies
PPTX
The tortoise and the ORM
PDF
ORMs in Golang
PPTX
ORM Methodology
PPT
Object Relational Mapping In Real World Applications
PDF
ORMs heróis ou vilões dentro da arquitetura de dados? - Otávio gonçalves
Micro ORM vs Entity Framework
Orms vs Micro-ORMs
Dapper: the microORM that will change your life
refORM: Death to ORMs in .NET
Advanced .NET Data Access with Dapper
Dapper - Rise of the MicroORM
How To Do Excel-Like Row Selection in jQuery DataTable?
Advanced data access with Dapper
ORMs Meet SQL
Object Relational Mapping with Dapper (Micro ORM)
Entity Framework Interview Questions PDF By ScholarHat
Orm loveandhate
Green dao
Microsoft Data Access Technologies
The tortoise and the ORM
ORMs in Golang
ORM Methodology
Object Relational Mapping In Real World Applications
ORMs heróis ou vilões dentro da arquitetura de dados? - Otávio gonçalves
Ad

Recently uploaded (20)

PDF
Module 7 guard mounting of security pers
PPTX
AcademyNaturalLanguageProcessing-EN-ILT-M02-Introduction.pptx
PPTX
NORMAN_RESEARCH_PRESENTATION.in education
PPTX
Module_4_Updated_Presentation CORRUPTION AND GRAFT IN THE PHILIPPINES.pptx
PPTX
PurpoaiveCommunication for students 02.pptx
DOCX
"Project Management: Ultimate Guide to Tools, Techniques, and Strategies (2025)"
PPTX
chapter8-180915055454bycuufucdghrwtrt.pptx
PDF
MODULE 3 BASIC SECURITY DUTIES AND ROLES.pdf
PPTX
Intro to ISO 9001 2015.pptx wareness raising
PPTX
_ISO_Presentation_ISO 9001 and 45001.pptx
PPTX
2025-08-17 Joseph 03 (shared slides).pptx
PPTX
Shizophrnia ppt for clinical psychology students of AS
PPTX
water for all cao bang - a charity project
PDF
6.-propertise of noble gases, uses and isolation in noble gases
PDF
PM Narendra Modi's speech from Red Fort on 79th Independence Day.pdf
PPT
First Aid Training Presentation Slides.ppt
PPTX
ART-APP-REPORT-FINctrwxsg f fuy L-na.pptx
PDF
Presentation1 [Autosaved].pdf diagnosiss
PPTX
3RD-Q 2022_EMPLOYEE RELATION - Copy.pptx
PPTX
ANICK 6 BIRTHDAY....................................................
Module 7 guard mounting of security pers
AcademyNaturalLanguageProcessing-EN-ILT-M02-Introduction.pptx
NORMAN_RESEARCH_PRESENTATION.in education
Module_4_Updated_Presentation CORRUPTION AND GRAFT IN THE PHILIPPINES.pptx
PurpoaiveCommunication for students 02.pptx
"Project Management: Ultimate Guide to Tools, Techniques, and Strategies (2025)"
chapter8-180915055454bycuufucdghrwtrt.pptx
MODULE 3 BASIC SECURITY DUTIES AND ROLES.pdf
Intro to ISO 9001 2015.pptx wareness raising
_ISO_Presentation_ISO 9001 and 45001.pptx
2025-08-17 Joseph 03 (shared slides).pptx
Shizophrnia ppt for clinical psychology students of AS
water for all cao bang - a charity project
6.-propertise of noble gases, uses and isolation in noble gases
PM Narendra Modi's speech from Red Fort on 79th Independence Day.pdf
First Aid Training Presentation Slides.ppt
ART-APP-REPORT-FINctrwxsg f fuy L-na.pptx
Presentation1 [Autosaved].pdf diagnosiss
3RD-Q 2022_EMPLOYEE RELATION - Copy.pptx
ANICK 6 BIRTHDAY....................................................
Ad

Review of micro Orm in c#