欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ORM框架之Dapper簡介和性能測試

 更新時間:2022年01月01日 07:55:28   作者:QFN-齊  
這篇文章介紹了ORM框架之Dapper簡介和性能測試,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

Dapper的簡介

Dapper是.NET下一個micro的ORM,它和Entity Framework或Nhibnate不同,屬于輕量級的,并且是半自動的。Dapper只有一個代碼文件,完全開源,你可以放在項目里的任何位置,來實現(xiàn)數(shù)據(jù)到對象的ORM操作,體積小速度快。 使用ORM的好處是增、刪、改很快,不用自己寫sql,因為這都是重復(fù)技術(shù)含量低的工作,還有就是程序中大量的從數(shù)據(jù)庫中讀數(shù)據(jù)然后創(chuàng)建model,并為model字段賦值。這些ORM都可以輕松給你搞定。ORM給我們開發(fā)帶來便利時,性能也是一個讓我們不得不考慮的問題。一般的ORM性能和直接寫原生的sql比都差不少,但是Dapper性能還很錯,甚至和DbHelperSQL方式性能高出很多。

Dapper的優(yōu)勢

  1. Dapper是一個輕型的ORM類。代碼就一個SqlMapper.cs文件,編譯后體積小。
  2. Dapper很快。Dapper的速度接近與IDataReader,取列表的數(shù)據(jù)超過了DataTable。
  3. Dapper支持多數(shù)據(jù)庫。諸如:Mysql,SqlLite,Mssql系列,Oracle等一系列的數(shù)據(jù)庫。
  4. Dapper的R支持多表并聯(lián)的對象。支持一對多 多對多的關(guān)系。并且沒侵入性,想用就用,不想用就不用,無XML無屬性,代碼以前怎么寫現(xiàn)在還怎么寫。
  5. Dapper原理通過Emit反射IDataReader的序列隊列,來快速的得到和產(chǎn)生對象,性能高。
  6. Dapper支持net2.0及以上版本
  7. Dapper語法十分簡單,并且無須遷就數(shù)據(jù)庫的設(shè)計。

Dapper的性能

Dapper 的主要特點是性能。以下數(shù)據(jù)顯示對一個數(shù)據(jù)庫執(zhí)行 SELECT 出 500 條,并把數(shù)據(jù)映射到對象中需要多長時間。

性能測試分為三個方面:

  1. POCO 序列化框架,支持從數(shù)據(jù)庫獲得靜態(tài)類型的對象。使用原始的 SQL。
  2. 動態(tài)序列化框架,支持返回對象的動態(tài)列表。
  3. 典型的框架用法。往往不會涉及編寫 SQL。

1. Performance of SELECT mapping over 500 iterations - POCO 序列化

方法持續(xù)時間(毫秒)備注
Hand coded (using a SqlDataReader)47Can be faster
Dapper ExecuteMapperQuery49同上
ServiceStack.OrmLite (QueryById)50同上
PetaPoco52同上
BLToolkit80同上
SubSonic CodingHorror107同上
NHibernate SQL104同上
Linq 2 SQL ExecuteQuery181同上
Entity framework ExecuteStoreQuery631同上

2. Performance of SELECT mapping over 500 iterations - dynamic 序列化

方法持續(xù)時間(毫秒)備注
Dapper ExecuteMapperQuery (dynamic)48 
Massive52 
Simple.Data95 

3. Performance of SELECT mapping over 500 iterations - 典型用法

方法 持續(xù)時間(毫秒)備注
Linq 2 SQL CompiledQuery81Not super typical involves complex code
NHibernate HQL118 
Linq 2 SQL559 
Entity framework859 
SubSonic ActiveRecord.SingleOrDefault3619 

其他見解:

  1. 能很方便地執(zhí)行數(shù)據(jù)庫 DML 和 DLL 操作。比如,當(dāng)你執(zhí)行一個帶參數(shù)的 SQL 時,SQL 中的變量能與你傳遞給它的實體或匿名對象中的屬性,自定匹配。而我們知道,帶參數(shù)的 SQL,能提高數(shù)據(jù)庫執(zhí)行 SQL 的效率。
  2. 能很方便地將數(shù)據(jù)庫檢索結(jié)果映射為面向?qū)ο蟮膶ο?。從?shù)據(jù)庫中的檢索結(jié)果,通常是張二維表,如 DataTable,而應(yīng)用程序中是實體類,以及實體類的集合,那么 Dapper 能夠?qū)?DataTable 自動地映射成為實體類的集合。
  3. 能很方便地書寫 SQL 語句。比如,寫多個 SQL,用分號分隔。

到此這篇關(guān)于ORM框架之Dapper簡介和性能測試的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論