這篇文章受大家邀請,與 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
編碼的過程
這個錯誤來自 sugar 創建數據庫的時候,實體定義如下:
sugar的沒有同步上來。
暫時先用 freesql 幫 sugar 創建了表。。。創建完后如下:
運行時又出現如下錯誤:
需要加一堆 IsIgnore
是的,還在報錯,最終原因是我傳入的 songs 是 IEnumerable
以 SqlServer 作為目標庫,測試結果
第一次:
第二次:
EFCore 也參與進來的測試:
uploading-image-353246.png
以 MySql 作為目標庫,測試結果
EFCore 也參與進來的測試:
結束語
然而上面提到的批量更新,今天先到這吧。下次有興致了再測試。
其他庫我就不測試了,謝謝觀看!請求獻上寶貴的一星。
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