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
测试结果
废话不多说先看测试结果,以下测试结果对排名进行不同颜色区分以下是颜色区分的图示
data:image/s3,"s3://crabby-images/21ed8/21ed8baf6136871bc5dda65fae7e111c4e77d5af" alt=""
第一台电脑测试结果
dapper efcore hisql sqlsugar freesql10列以下的常规数据插入测试结果
data:image/s3,"s3://crabby-images/e977a/e977aaafc5302c9964e7ac26b8667668839152be" alt=""
这个测试结果有没有让人很意外 efcore说实在的在很多网友的印象中应该还算是不错的,结果测试出来...(不会有人说我在黑efcore吧) 我只是基于这个测试结果来说
dapper efcore hisql sqlsugar freesql 50列常规数据插入测试结果
data:image/s3,"s3://crabby-images/873ff/873ffcd23a01359d869a1a4a9ccfa2e14f4e7205" alt=""
50列的 efcore 就更加明显了 ,至于排名我请大家自己评判吧
好了, 这是第一台测试电脑的结果
第二台电脑测试结果
dapper efcore hisql sqlsugar freesql10列以下的常规数据插入测试结果
data:image/s3,"s3://crabby-images/ce066/ce066fd94fc02f2405a3fadf77b049b1dcf51926" alt=""
这台电脑的配置排名相对于第一台电脑有一点变化
dapper efcore hisql sqlsugar freesql 50列常规数据插入测试结果
data:image/s3,"s3://crabby-images/5d2fc/5d2fce7d127067d46f23889f8bef053d210ecd21" alt=""
第一台电脑的测试明细截图
第一台电脑5条10列以下插入截图
data:image/s3,"s3://crabby-images/f237c/f237ca807127d020f50d2177bda3e7dd3c0e0067" alt=""
第一台电脑50条10列以下插入截图
data:image/s3,"s3://crabby-images/3ffae/3ffaef00a044c86a3ec7c3bb2667962a092d9277" alt=""
第一台电脑100条10列以下插入截图
data:image/s3,"s3://crabby-images/1135b/1135ba9b6595e5c39cb734cf7ac00373ca14831d" alt=""
第一台电脑500条10列以下插入截图
data:image/s3,"s3://crabby-images/3cd23/3cd23decf7633137af68bb42a7c42dc0891ddf3c" alt=""
第一台电脑1000条10列以下插入截图
data:image/s3,"s3://crabby-images/d391d/d391df05a1fa8fa0dedacd28b75a3403435b4059" alt=""
第一台电脑5000条10列以下插入截图
data:image/s3,"s3://crabby-images/57d25/57d25762c2f4f801fcbd45ef1421720208eda786" alt=""
第一台电脑10000条10列以下插入截图
data:image/s3,"s3://crabby-images/f85d3/f85d38aa45c6ac513f998b120ce335894b711c51" alt=""
第一台电脑50000条10列以下插入截图
data:image/s3,"s3://crabby-images/1daf2/1daf2250bfa44782ecbdad93b07180abbdf68348" alt=""
第一台电脑100000条10列以下插入截图
data:image/s3,"s3://crabby-images/a11af/a11afdbddcc7c4375176be46df03828b66181da7" alt=""
第一台电脑5条50列插入截图
data:image/s3,"s3://crabby-images/01778/017789969f79127fca05760f70071c445135fc21" alt=""
第一台电脑50条50列插入截图
data:image/s3,"s3://crabby-images/16a9e/16a9ec5604feba78675298622b90eca781d55ffa" alt=""
第一台电脑100条50列插入截图
data:image/s3,"s3://crabby-images/53db9/53db9879ed521f9e8f3c51dd5544496fbc731cbe" alt=""
第一台电脑500条50列插入截图
data:image/s3,"s3://crabby-images/82343/82343bef7dc688c4d0e60545622e4d7a828785b5" alt=""
第一台电脑1000条50列插入截图
data:image/s3,"s3://crabby-images/58025/58025c1420ff170db21fb6c4c2ec456c52d8f0fd" alt=""
第一台电脑5000条50列插入截图
data:image/s3,"s3://crabby-images/bbb8c/bbb8c9abd3aec035a0ffbfb32577d9c189e20ffe" alt=""
第一台电脑10000条50列插入截图
data:image/s3,"s3://crabby-images/04af1/04af160dfae3e92be6c30a4c798eaabad24b1499" alt=""
第一台电脑50000条50列插入截图
data:image/s3,"s3://crabby-images/9ac39/9ac395f5a08d2f140ad1c2a2d0d090eb21dd41bb" alt=""
第一台电脑100000条50列插入截图
data:image/s3,"s3://crabby-images/6bb53/6bb53935ae474ae6e9787f15a9be77fe2a5ee318" alt=""
第二台电脑的测试明细截图
第二台电脑5条10列以下插入截图
data:image/s3,"s3://crabby-images/3b75a/3b75ac66cfd8dfc23ff3c259d4100687bbb3f35e" alt=""
第二台电脑50条10列以下插入截图
data:image/s3,"s3://crabby-images/d9198/d91984b799639488b1e90699ff1a9b00a65f9766" alt=""
第二台电脑100条10列以下插入截图
data:image/s3,"s3://crabby-images/a042e/a042e3e626c1b594e64f4ca14105bec830f2701f" alt=""
第二台电脑500条10列以下插入截图
data:image/s3,"s3://crabby-images/90a32/90a32768f2ce5c797f986e858799c2f4d49dabd8" alt=""
第二台电脑1000条10列以下插入截图
data:image/s3,"s3://crabby-images/9ac97/9ac97f6efeef7138552af17aeaac5f9d37b654c5" alt=""
第二台电脑5000条10列以下插入截图
data:image/s3,"s3://crabby-images/5a03a/5a03adc8f0fea2adb9b76aeb5ef81066bba966a3" alt=""
第二台电脑10000条10列以下插入截图
data:image/s3,"s3://crabby-images/67844/678448c400179e7b27a4feaddde18f71b783c8eb" alt=""
第二台电脑50000条10列以下插入截图
data:image/s3,"s3://crabby-images/61fdb/61fdbe59494355f6d20eb66c9beae473397df875" alt=""
第二台电脑100000条10列以下插入截图
data:image/s3,"s3://crabby-images/655c0/655c07f00b0e2136b276db384cfe4caff7cfb81d" alt=""
第二台电脑5条50列插入截图
data:image/s3,"s3://crabby-images/18737/187371972dad0d108661415becd1dcfbdfa249b4" alt=""
第二台电脑50条50列插入截图
data:image/s3,"s3://crabby-images/0be49/0be4906cc8399947f3a8aa4e88046261e971ce84" alt=""
第二台电脑100条50列插入截图
data:image/s3,"s3://crabby-images/52a40/52a40046e7febc5786f7e66f3e6b3dfe57f82bab" alt=""
第二台电脑500条50列插入截图
data:image/s3,"s3://crabby-images/bdbd5/bdbd50c3e90a60392618cb46881fa89a60cf3df0" alt=""
第二台电脑1000条50列插入截图
data:image/s3,"s3://crabby-images/5a720/5a72099c0b68e76544cf9c06ffd8723a33b29c7a" alt=""
第二台电脑5000条50列插入截图
data:image/s3,"s3://crabby-images/3d93f/3d93f827dc2fb3ffbf565dda74657748736b2821" alt=""
第二台电脑10000条50列插入截图
data:image/s3,"s3://crabby-images/a918b/a918b0b3ce48274e0aa5c3f2360670660e433c92" alt=""
第二台电脑50000条50列插入截图
data:image/s3,"s3://crabby-images/d5f62/d5f62e2e2e0b34fb30f328c6054ad626cc683e44" alt=""
第二台电脑100000条50列插入截图
data:image/s3,"s3://crabby-images/f14d4/f14d44b139cf2aec10e7a9c893bebc005c996eb9" alt=""
测试电脑配置
两台一模一样配置电脑
第一台电脑配置
内存,CPU 相关配置
data:image/s3,"s3://crabby-images/a39bc/a39bc0ac026908d7a50fb00adeba8d8998af9674" alt=""
sqlserver 版本信息
data:image/s3,"s3://crabby-images/6fd10/6fd10d3af92ad928321f123c021794eae05ebf8a" alt=""
第二台电脑配置
内存,CPU 相关配置
data:image/s3,"s3://crabby-images/fe3dc/fe3dc3ff5279514da16d4c347c7e83695870ebbf" alt=""
sqlserver 版本信息
data:image/s3,"s3://crabby-images/4b495/4b495663f10dfbc92761c420ea219f311ecd7b77" alt=""
总结
本测试结果仅作参考,在不同的电脑环境可能体现出来的测试结果可能有差异,但整体排名差不大
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |