当前位置:   article > 正文

FreeSql 与 SqlSugar 性能测试(增EFCore测试结果)

sqlsugar与efcore

这篇文章受大家邀请,与 SqlSugar 做一次简单的性能测试对比。主要针对插入、批量插入、批量更新、读取性能的测试;

测试环境

  • .net core 2.2
  • FreeSql 0.3.17
  • sqlSugarCore 4.9.9.3

  • sqlserver 14.00.1000 Express、mysql 5.6

测试项目

以 console 程序,创建步骤:

1、dotnet new console

2、dotnet add package FreeSql

3、dotnet add package sqlSugarCore

编码的过程

31407-20190319123532937-314302761.png

这个错误来自 sugar 创建数据库的时候,实体定义如下:

31407-20190319124951104-636446633.png

31407-20190319123659440-1322977883.png
sugar的没有同步上来。

暂时先用 freesql 帮 sugar 创建了表。。。创建完后如下:

31407-20190319123727923-381984025.png

运行时又出现如下错误:

31407-20190319123836372-72094214.png

需要加一堆 IsIgnore

31407-20190319123856790-330320416.png

是的,还在报错,最终原因是我传入的 songs 是 IEnumerable,然后接受的参数类型正常应该是 Song[],希望作者看到了可以改进。

31407-20190319123930837-569250831.png

以 SqlServer 作为目标库,测试结果

第一次:
31407-20190319123452177-1200763409.png

第二次:
31407-20190319131618354-1111756658.png

EFCore 也参与进来的测试:
31407-20190319150116516-1804755786.png

uploading-image-353246.png

以 MySql 作为目标库,测试结果

31407-20190319124057151-1851045429.png

EFCore 也参与进来的测试:
31407-20190319151446722-1665781583.png

结束语

然而上面提到的批量更新,今天先到这吧。下次有兴致了再测试。

其他库我就不测试了,谢谢观看!请求献上宝贵的一星。

github:https://github.com/2881099/FreeSql

然后 针对测试的实体类,FreeSql 可以这样查询:

一对一、多对一的查询:

var t0 = fsql.Select<Tag>().Where(a => a.Parent.Parent.Name == "粤语").ToSql();

一对多的查询:

var t1 = fsql.Select<Tag>().Where(a => a.Tags.AsSelect().Any(t => t.Parent.Id == 10)).ToSql();

多对多的查询:

var t2 = fsql.Select<Song>().Where(s => s.Tags.AsSelect().Any(t => t.Name == "国语")).ToSql();

最终的测试代码:https://github.com/2881099/FreeSql/blob/master/Examples/orm_vs/Program.cs

转载于:https://www.cnblogs.com/kellynic/p/10557882.html

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/135080
推荐阅读
相关标签
  

闽ICP备14008679号