FreeSql 与 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值