mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-04-05 17:37:58 +08:00
性能对比
This commit is contained in:
parent
e351a33d83
commit
4cd25576fa
@ -10,6 +10,7 @@ namespace PerformanceTest
|
|||||||
{
|
{
|
||||||
SqlSugar,
|
SqlSugar,
|
||||||
Dapper,
|
Dapper,
|
||||||
EF
|
EF,
|
||||||
|
FREE
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -49,13 +49,26 @@
|
|||||||
<HintPath>..\packages\EntityFramework.6.1.3\lib\net45\EntityFramework.SqlServer.dll</HintPath>
|
<HintPath>..\packages\EntityFramework.6.1.3\lib\net45\EntityFramework.SqlServer.dll</HintPath>
|
||||||
<Private>True</Private>
|
<Private>True</Private>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
<Reference Include="FreeSql, Version=2.0.101.0, Culture=neutral, PublicKeyToken=a33928e5d4a4b39c, processorArchitecture=MSIL">
|
||||||
|
<HintPath>..\packages\FreeSql.2.0.101\lib\net45\FreeSql.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
<Reference Include="FreeSql.Provider.SqlServer, Version=2.0.101.0, Culture=neutral, PublicKeyToken=d313b98af285bd88, processorArchitecture=MSIL">
|
||||||
|
<HintPath>..\packages\FreeSql.Provider.SqlServer.2.0.101\lib\net451\FreeSql.Provider.SqlServer.dll</HintPath>
|
||||||
|
<Private>True</Private>
|
||||||
|
</Reference>
|
||||||
<Reference Include="SyntacticSugar, Version=2.4.1.0, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="SyntacticSugar, Version=2.4.1.0, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\SyntacticSugar.2.4.1\lib\net40\SyntacticSugar.dll</HintPath>
|
<HintPath>..\packages\SyntacticSugar.2.4.1\lib\net40\SyntacticSugar.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="System" />
|
<Reference Include="System" />
|
||||||
<Reference Include="System.ComponentModel.DataAnnotations" />
|
<Reference Include="System.ComponentModel.DataAnnotations" />
|
||||||
<Reference Include="System.Core" />
|
<Reference Include="System.Core" />
|
||||||
|
<Reference Include="System.Data.Common, Version=4.1.1.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
|
||||||
|
<HintPath>..\packages\System.Data.Common.4.3.0\lib\net451\System.Data.Common.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
<Reference Include="System.Data.Linq" />
|
<Reference Include="System.Data.Linq" />
|
||||||
|
<Reference Include="System.Data.SqlClient, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL">
|
||||||
|
<HintPath>..\packages\System.Data.SqlClient.4.8.2\lib\net451\System.Data.SqlClient.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
<Reference Include="System.Xml.Linq" />
|
<Reference Include="System.Xml.Linq" />
|
||||||
<Reference Include="System.Data.DataSetExtensions" />
|
<Reference Include="System.Data.DataSetExtensions" />
|
||||||
<Reference Include="Microsoft.CSharp" />
|
<Reference Include="Microsoft.CSharp" />
|
||||||
@ -74,6 +87,7 @@
|
|||||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
<Compile Include="TestItems\TestGetSql.cs" />
|
<Compile Include="TestItems\TestGetSql.cs" />
|
||||||
<Compile Include="TestItems\TestInsert.cs" />
|
<Compile Include="TestItems\TestInsert.cs" />
|
||||||
|
<Compile Include="TestItems\TestLike.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="App.config" />
|
<None Include="App.config" />
|
||||||
|
@ -18,8 +18,8 @@ namespace PerformanceTest
|
|||||||
{
|
{
|
||||||
InitData();
|
InitData();
|
||||||
|
|
||||||
var type = DemoType.Insert;
|
var type = DemoType.GetById;
|
||||||
var ormType = OrmType.EF;
|
var ormType = OrmType.SqlSugar;
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
case DemoType.GetAll:
|
case DemoType.GetAll:
|
||||||
@ -34,6 +34,9 @@ namespace PerformanceTest
|
|||||||
case DemoType.Insert:
|
case DemoType.Insert:
|
||||||
new TestInsert().Init(ormType);
|
new TestInsert().Init(ormType);
|
||||||
break;
|
break;
|
||||||
|
case DemoType.Like:
|
||||||
|
new TestLike().Init(ormType);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -78,7 +81,8 @@ namespace PerformanceTest
|
|||||||
GetAll,
|
GetAll,
|
||||||
GetById,
|
GetById,
|
||||||
GetSql,
|
GetSql,
|
||||||
Insert
|
Insert,
|
||||||
|
Like
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,9 @@ namespace PerformanceTest.TestItems
|
|||||||
case OrmType.EF:
|
case OrmType.EF:
|
||||||
EF(eachCount);
|
EF(eachCount);
|
||||||
break;
|
break;
|
||||||
|
case OrmType.FREE:
|
||||||
|
Free(eachCount);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -50,11 +53,25 @@ namespace PerformanceTest.TestItems
|
|||||||
{
|
{
|
||||||
using (SqlSugarClient conn = Config.GetSugarConn())
|
using (SqlSugarClient conn = Config.GetSugarConn())
|
||||||
{
|
{
|
||||||
var list2 = conn.Queryable<Test>().InSingle(1);
|
var list2 = conn.Queryable<Test>().First(it=>it.Id==1);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
private static void Free(int eachCount)
|
||||||
|
{
|
||||||
|
GC.Collect();//回收资源
|
||||||
|
System.Threading.Thread.Sleep(1);//休息1秒
|
||||||
|
|
||||||
|
PerHelper.Execute(eachCount, "free", () =>
|
||||||
|
{
|
||||||
|
IFreeSql fsql = new FreeSql.FreeSqlBuilder()
|
||||||
|
.UseConnectionString(FreeSql.DataType.SqlServer, Config.connectionString)
|
||||||
|
.UseAutoSyncStructure(false) //自动同步实体结构到数据库
|
||||||
|
.Build();
|
||||||
|
var list2 = fsql.Queryable<Test>().Where(it=>it.Id==1).First();
|
||||||
|
//用.First(it=>it.Id==1)报错
|
||||||
|
});
|
||||||
|
}
|
||||||
private static void Dapper(int eachCount)
|
private static void Dapper(int eachCount)
|
||||||
{
|
{
|
||||||
GC.Collect();//回收资源
|
GC.Collect();//回收资源
|
||||||
|
81
Src/Asp.Net/PerformanceTest/TestItems/TestLike.cs
Normal file
81
Src/Asp.Net/PerformanceTest/TestItems/TestLike.cs
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
using Dapper;
|
||||||
|
using SqlSugar;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Data.Entity;
|
||||||
|
using System.Data.SqlClient;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace PerformanceTest.TestItems
|
||||||
|
{
|
||||||
|
public class TestLike
|
||||||
|
{
|
||||||
|
public void Init(OrmType type)
|
||||||
|
{
|
||||||
|
Database.SetInitializer<EFContext>(null);
|
||||||
|
Console.WriteLine("测试SQL查询的速度");
|
||||||
|
var eachCount = 1;
|
||||||
|
|
||||||
|
var beginDate = DateTime.Now;
|
||||||
|
for (int i = 0; i < 20; i++)
|
||||||
|
{
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case OrmType.SqlSugar:
|
||||||
|
SqlSugar(eachCount);
|
||||||
|
break;
|
||||||
|
case OrmType.Dapper:
|
||||||
|
Dapper(eachCount);
|
||||||
|
break;
|
||||||
|
case OrmType.EF:
|
||||||
|
EF(eachCount);
|
||||||
|
break;
|
||||||
|
case OrmType.FREE:
|
||||||
|
Free(eachCount);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Console.Write("总计:" + (DateTime.Now - beginDate).TotalMilliseconds / 1000.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static void Free(int eachCount)
|
||||||
|
{
|
||||||
|
GC.Collect();//回收资源
|
||||||
|
System.Threading.Thread.Sleep(1);//休息1秒
|
||||||
|
|
||||||
|
PerHelper.Execute(eachCount, "Free like ", () =>
|
||||||
|
{
|
||||||
|
IFreeSql fsql = new FreeSql.FreeSqlBuilder()
|
||||||
|
.UseConnectionString(FreeSql.DataType.SqlServer,Config.connectionString)
|
||||||
|
.UseAutoSyncStructure(false) //自动同步实体结构到数据库
|
||||||
|
.Build();
|
||||||
|
var list2 = fsql.Queryable<Test>().Where(it => it.F_String.Contains("abc")).ToList();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SqlSugar(int eachCount)
|
||||||
|
{
|
||||||
|
GC.Collect();//回收资源
|
||||||
|
System.Threading.Thread.Sleep(1);//休息1秒
|
||||||
|
|
||||||
|
PerHelper.Execute(eachCount, "SqlSugar like ", () =>
|
||||||
|
{
|
||||||
|
SqlSugarClient conn = Config.GetSugarConn();
|
||||||
|
var list2 = conn.Queryable<Test>().Where(it => it.F_String.Contains("abc")).ToList();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void Dapper(int eachCount)
|
||||||
|
{
|
||||||
|
throw new Exception("未实现");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void EF(int eachCount)
|
||||||
|
{
|
||||||
|
throw new Exception("未实现");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -4,5 +4,9 @@
|
|||||||
<package id="Dapper.Contrib" version="1.50.0" targetFramework="net452" />
|
<package id="Dapper.Contrib" version="1.50.0" targetFramework="net452" />
|
||||||
<package id="Dapper.Extension" version="1.0.0.1" targetFramework="net452" />
|
<package id="Dapper.Extension" version="1.0.0.1" targetFramework="net452" />
|
||||||
<package id="EntityFramework" version="6.1.3" targetFramework="net452" />
|
<package id="EntityFramework" version="6.1.3" targetFramework="net452" />
|
||||||
|
<package id="FreeSql" version="2.0.101" targetFramework="net452" />
|
||||||
|
<package id="FreeSql.Provider.SqlServer" version="2.0.101" targetFramework="net452" />
|
||||||
<package id="SyntacticSugar" version="2.4.1" targetFramework="net452" />
|
<package id="SyntacticSugar" version="2.4.1" targetFramework="net452" />
|
||||||
|
<package id="System.Data.Common" version="4.3.0" targetFramework="net452" />
|
||||||
|
<package id="System.Data.SqlClient" version="4.8.2" targetFramework="net452" />
|
||||||
</packages>
|
</packages>
|
Loading…
Reference in New Issue
Block a user