ORM框架之Dapper簡(jiǎn)介和性能測(cè)試
Dapper的簡(jiǎn)介
Dapper是.NET下一個(gè)micro的ORM,它和Entity Framework或Nhibnate不同,屬于輕量級(jí)的,并且是半自動(dòng)的。Dapper只有一個(gè)代碼文件,完全開(kāi)源,你可以放在項(xiàng)目里的任何位置,來(lái)實(shí)現(xiàn)數(shù)據(jù)到對(duì)象的ORM操作,體積小速度快。 使用ORM的好處是增、刪、改很快,不用自己寫(xiě)sql,因?yàn)檫@都是重復(fù)技術(shù)含量低的工作,還有就是程序中大量的從數(shù)據(jù)庫(kù)中讀數(shù)據(jù)然后創(chuàng)建model,并為model字段賦值。這些ORM都可以輕松給你搞定。ORM給我們開(kāi)發(fā)帶來(lái)便利時(shí),性能也是一個(gè)讓我們不得不考慮的問(wèn)題。一般的ORM性能和直接寫(xiě)原生的sql比都差不少,但是Dapper性能還很錯(cuò),甚至和DbHelperSQL方式性能高出很多。
Dapper的優(yōu)勢(shì)
- Dapper是一個(gè)輕型的ORM類(lèi)。代碼就一個(gè)SqlMapper.cs文件,編譯后體積小。
- Dapper很快。Dapper的速度接近與IDataReader,取列表的數(shù)據(jù)超過(guò)了DataTable。
- Dapper支持多數(shù)據(jù)庫(kù)。諸如:Mysql,SqlLite,Mssql系列,Oracle等一系列的數(shù)據(jù)庫(kù)。
- Dapper的R支持多表并聯(lián)的對(duì)象。支持一對(duì)多 多對(duì)多的關(guān)系。并且沒(méi)侵入性,想用就用,不想用就不用,無(wú)XML無(wú)屬性,代碼以前怎么寫(xiě)現(xiàn)在還怎么寫(xiě)。
- Dapper原理通過(guò)Emit反射IDataReader的序列隊(duì)列,來(lái)快速的得到和產(chǎn)生對(duì)象,性能高。
- Dapper支持net2.0及以上版本
- Dapper語(yǔ)法十分簡(jiǎn)單,并且無(wú)須遷就數(shù)據(jù)庫(kù)的設(shè)計(jì)。
Dapper的性能
Dapper 的主要特點(diǎn)是性能。以下數(shù)據(jù)顯示對(duì)一個(gè)數(shù)據(jù)庫(kù)執(zhí)行 SELECT 出 500 條,并把數(shù)據(jù)映射到對(duì)象中需要多長(zhǎng)時(shí)間。
性能測(cè)試分為三個(gè)方面:
- POCO 序列化框架,支持從數(shù)據(jù)庫(kù)獲得靜態(tài)類(lèi)型的對(duì)象。使用原始的 SQL。
- 動(dòng)態(tài)序列化框架,支持返回對(duì)象的動(dòng)態(tài)列表。
- 典型的框架用法。往往不會(huì)涉及編寫(xiě) SQL。
1. Performance of SELECT mapping over 500 iterations - POCO 序列化
| 方法 | 持續(xù)時(shí)間(毫秒) | 備注 |
| Hand coded (using a SqlDataReader) | 47 | Can be faster |
| Dapper ExecuteMapperQuery | 49 | 同上 |
| ServiceStack.OrmLite (QueryById) | 50 | 同上 |
| PetaPoco | 52 | 同上 |
| BLToolkit | 80 | 同上 |
| SubSonic CodingHorror | 107 | 同上 |
| NHibernate SQL | 104 | 同上 |
| Linq 2 SQL ExecuteQuery | 181 | 同上 |
| Entity framework ExecuteStoreQuery | 631 | 同上 |
2. Performance of SELECT mapping over 500 iterations - dynamic 序列化
| 方法 | 持續(xù)時(shí)間(毫秒) | 備注 |
| Dapper ExecuteMapperQuery (dynamic) | 48 | |
| Massive | 52 | |
| Simple.Data | 95 |
3. Performance of SELECT mapping over 500 iterations - 典型用法
| 方法 | 持續(xù)時(shí)間(毫秒) | 備注 |
| Linq 2 SQL CompiledQuery | 81 | Not super typical involves complex code |
| NHibernate HQL | 118 | |
| Linq 2 SQL | 559 | |
| Entity framework | 859 | |
| SubSonic ActiveRecord.SingleOrDefault | 3619 |
其他見(jiàn)解:
- 能很方便地執(zhí)行數(shù)據(jù)庫(kù) DML 和 DLL 操作。比如,當(dāng)你執(zhí)行一個(gè)帶參數(shù)的 SQL 時(shí),SQL 中的變量能與你傳遞給它的實(shí)體或匿名對(duì)象中的屬性,自定匹配。而我們知道,帶參數(shù)的 SQL,能提高數(shù)據(jù)庫(kù)執(zhí)行 SQL 的效率。
- 能很方便地將數(shù)據(jù)庫(kù)檢索結(jié)果映射為面向?qū)ο蟮膶?duì)象。從數(shù)據(jù)庫(kù)中的檢索結(jié)果,通常是張二維表,如 DataTable,而應(yīng)用程序中是實(shí)體類(lèi),以及實(shí)體類(lèi)的集合,那么 Dapper 能夠?qū)?DataTable 自動(dòng)地映射成為實(shí)體類(lèi)的集合。
- 能很方便地書(shū)寫(xiě) SQL 語(yǔ)句。比如,寫(xiě)多個(gè) SQL,用分號(hào)分隔。
到此這篇關(guān)于ORM框架之Dapper簡(jiǎn)介和性能測(cè)試的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 輕量級(jí)ORM框架Dapper應(yīng)用支持操作函數(shù)和事物
- 輕量級(jí)ORM框架Dapper應(yīng)用之Dapper支持存儲(chǔ)過(guò)程
- 輕量級(jí)ORM框架Dapper應(yīng)用之實(shí)現(xiàn)Join操作
- 輕量級(jí)ORM框架Dapper應(yīng)用之返回多個(gè)結(jié)果集
- 輕量級(jí)ORM框架Dapper應(yīng)用之實(shí)現(xiàn)In操作
- 輕量級(jí)ORM框架Dapper應(yīng)用之實(shí)現(xiàn)CURD操作
- 輕量級(jí)ORM框架Dapper應(yīng)用之安裝Dapper
- 輕量級(jí)ORM框架Dapper應(yīng)用之實(shí)現(xiàn)DTO
相關(guān)文章
.Net Core使用SignalR實(shí)現(xiàn)斗地主游戲
本文詳細(xì)講解了.Net Core使用SignalR實(shí)現(xiàn)斗地主游戲的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-01-01
搭建基礎(chǔ)結(jié)構(gòu)的ABP解決方案介紹
這篇文章介紹了搭建基礎(chǔ)結(jié)構(gòu)的ABP解決方案的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
ASP.NET中CheckBoxList復(fù)選框列表控件詳細(xì)使用方法
本文主要介紹CheckBoxList幾種常見(jiàn)的用法,并做出范例演示供大家參考,希望對(duì)學(xué)習(xí)asp.net的朋友有所幫助。2016-04-04
asp.net(C#) Access 數(shù)據(jù)操作類(lèi)
asp.net(C#) Access 數(shù)據(jù)操作類(lèi) 實(shí)現(xiàn)代碼,有需要這方面的朋友可以熟悉下。2009-06-06
ASP.net(c#)打造24小時(shí)天氣預(yù)報(bào)及實(shí)時(shí)天氣
ASP.net(c#)打造24小時(shí)天氣預(yù)報(bào)及實(shí)時(shí)天氣...2006-12-12

