在程式開發過程中,我們一般會用到配置文件來設定一些參數。常見的配置文件格式為 **ini**, **xml**, **config**等。 ...
c# 國內外ORM 框架 dapper efcore sqlsugar freesql hisql sqlserver數據常規插入測試性能對比對比
在6.22 號發佈了 c# sqlsugar,hisql,freesql orm框架全方位性能測試對比 sqlserver 性能測試 引起了很多爭議
聲明
首先我還是要做一下聲明,測的都是開源軟體,都是有開源協議的,而且測試源碼已經開放不存在有故意黑的主觀意圖,測試結果僅為博主的電腦的配置測試的結果為測試結果呈現,測試結果不為最終結果。如果有意見請文明反饋,不接受任何形式的威脅與刪博!!!
上次有部分網友說要對比一下efcore 和dapper的對比測試。那麼這次來一次國內外ORM進行測試對比。
不過有點遺憾的是 目前dapper 和efcore 官方包中沒有bulkcopy的功能(第三方插件有),因為官方沒有如果拿第三方插件來做bulkcopy的對比這樣有失公允,所以本次測試不測bulkcopy的,如果網友有比較認可的第三方插件那麼下一次安排上。
經過上一次的測試經驗 這次博主用兩臺電腦測試 兩臺電腦的配置如下
測試方案
- 因為不同的列插入的性能和時間肯定是有差別的本測試採用10列以下的數據集和50列的數據集進行測試
- 從5,50,100,500,1000,5000,10000,50000,100000 的數據階段進行對比測試
- 為了防止有人說一臺電腦測試不准,那麼這次使用兩台相同配置的電腦進行對比測試
- 測試的源碼 上傳到github
- 所有相關ORM的包都通過nuget安裝最新版本2022.6.28前發佈的
- 運行的測試程式都是在release環境運行
- 多個ORM同時運行,如果有影響那麼整體相互影響測試相對是公平的
- 每個ORM插入的是獨立的專用表,但結構是一模一樣(不存在表不同的問題)
測試源碼https://github.com/tansar/HiSqlTestDemo
測試結果
廢話不多說先看測試結果,以下測試結果對排名進行不同顏色區分以下是顏色區分的圖示
第一臺電腦測試結果
dapper efcore hisql sqlsugar freesql10列以下的常規數據插入測試結果
這個測試結果有沒有讓人很意外 efcore說實在的在很多網友的印象中應該還算是不錯的,結果測試出來...(不會有人說我在黑efcore吧) 我只是基於這個測試結果來說
dapper efcore hisql sqlsugar freesql 50列常規數據插入測試結果
50列的 efcore 就更加明顯了 ,至於排名我請大家自己評判吧
好了, 這是第一臺測試電腦的結果
第二臺電腦測試結果
dapper efcore hisql sqlsugar freesql10列以下的常規數據插入測試結果
這臺電腦的配置排名相對於第一臺電腦有一點變化
dapper efcore hisql sqlsugar freesql 50列常規數據插入測試結果
第一臺電腦的測試明細截圖
第一臺電腦5條10列以下插入截圖
第一臺電腦50條10列以下插入截圖
第一臺電腦100條10列以下插入截圖
第一臺電腦500條10列以下插入截圖
第一臺電腦1000條10列以下插入截圖
第一臺電腦5000條10列以下插入截圖
第一臺電腦10000條10列以下插入截圖
第一臺電腦50000條10列以下插入截圖
第一臺電腦100000條10列以下插入截圖
第一臺電腦5條50列插入截圖
第一臺電腦50條50列插入截圖
第一臺電腦100條50列插入截圖
第一臺電腦500條50列插入截圖
第一臺電腦1000條50列插入截圖
第一臺電腦5000條50列插入截圖
第一臺電腦10000條50列插入截圖
第一臺電腦50000條50列插入截圖
第一臺電腦100000條50列插入截圖
第二臺電腦的測試明細截圖
第二臺電腦5條10列以下插入截圖
第二臺電腦50條10列以下插入截圖
第二臺電腦100條10列以下插入截圖
第二臺電腦500條10列以下插入截圖
第二臺電腦1000條10列以下插入截圖
第二臺電腦5000條10列以下插入截圖
第二臺電腦10000條10列以下插入截圖
第二臺電腦50000條10列以下插入截圖
第二臺電腦100000條10列以下插入截圖
第二臺電腦5條50列插入截圖
第二臺電腦50條50列插入截圖
第二臺電腦100條50列插入截圖
第二臺電腦500條50列插入截圖
第二臺電腦1000條50列插入截圖
第二臺電腦5000條50列插入截圖
第二臺電腦10000條50列插入截圖
第二臺電腦50000條50列插入截圖
第二臺電腦100000條50列插入截圖
測試電腦配置
兩台一模一樣配置電腦
第一臺電腦配置
記憶體,CPU 相關配置
sqlserver 版本信息
第二臺電腦配置
記憶體,CPU 相關配置
sqlserver 版本信息
總結
本測試結果僅作參考,在不同的電腦環境可能體現出來的測試結果可能有差異,但整體排名差不大