mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-06-28 13:34:32 +08:00
Update demo
This commit is contained in:
parent
69ce8bb81b
commit
560e07c5c9
@ -17,4 +17,12 @@
|
|||||||
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
|
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
|
||||||
</providers>
|
</providers>
|
||||||
</entityFramework>
|
</entityFramework>
|
||||||
|
<runtime>
|
||||||
|
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
|
||||||
|
<dependentAssembly>
|
||||||
|
<assemblyIdentity name="FreeSql" publicKeyToken="a33928e5d4a4b39c" culture="neutral" />
|
||||||
|
<bindingRedirect oldVersion="0.0.0.0-2.0.105.0" newVersion="2.0.105.0" />
|
||||||
|
</dependentAssembly>
|
||||||
|
</assemblyBinding>
|
||||||
|
</runtime>
|
||||||
</configuration>
|
</configuration>
|
37
Src/Asp.Net/PerformanceTest/Models/ModelTest.cs
Normal file
37
Src/Asp.Net/PerformanceTest/Models/ModelTest.cs
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
using PerformanceTest.Models;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
namespace PerformanceTest.Models2
|
||||||
|
{
|
||||||
|
public class Group
|
||||||
|
{
|
||||||
|
[SqlSugar.SugarColumn(IsPrimaryKey = true)]
|
||||||
|
public int Id { get; set; } //Id、GroupId、Group_id
|
||||||
|
public string Name { get; set; }
|
||||||
|
[SqlSugar.SugarColumn(IsIgnore = true)]
|
||||||
|
public List<User> AUsers { get; set; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
namespace PerformanceTest.Models
|
||||||
|
{
|
||||||
|
public class Group
|
||||||
|
{
|
||||||
|
[SqlSugar.SugarColumn(IsPrimaryKey =true)]
|
||||||
|
public int Id { get; set; } //Id、GroupId、Group_id
|
||||||
|
public string Name { get; set; }
|
||||||
|
[SqlSugar.SugarColumn(IsIgnore =true)]
|
||||||
|
public ICollection<User> AUsers { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class User
|
||||||
|
{
|
||||||
|
[SqlSugar.SugarColumn(IsPrimaryKey = true)]
|
||||||
|
public int Id { get; set; } //Id、UserId、User_id
|
||||||
|
public int AGroupId { get; set; }
|
||||||
|
[SqlSugar.SugarColumn(IsIgnore = true)]
|
||||||
|
public Group AGroup { get; set; }
|
||||||
|
}
|
||||||
|
}
|
@ -49,12 +49,11 @@
|
|||||||
<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">
|
<Reference Include="FreeSql, Version=2.0.105.0, Culture=neutral, PublicKeyToken=a33928e5d4a4b39c, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\FreeSql.2.0.101\lib\net45\FreeSql.dll</HintPath>
|
<HintPath>..\packages\FreeSql.2.0.105\lib\net45\FreeSql.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="FreeSql.Provider.SqlServer, Version=2.0.101.0, Culture=neutral, PublicKeyToken=d313b98af285bd88, processorArchitecture=MSIL">
|
<Reference Include="FreeSql.Provider.SqlServer, Version=2.0.105.0, Culture=neutral, PublicKeyToken=d313b98af285bd88, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\FreeSql.Provider.SqlServer.2.0.101\lib\net451\FreeSql.Provider.SqlServer.dll</HintPath>
|
<HintPath>..\packages\FreeSql.Provider.SqlServer.2.0.105\lib\net451\FreeSql.Provider.SqlServer.dll</HintPath>
|
||||||
<Private>True</Private>
|
|
||||||
</Reference>
|
</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>
|
||||||
@ -80,6 +79,8 @@
|
|||||||
<Compile Include="Common\OrmType.cs" />
|
<Compile Include="Common\OrmType.cs" />
|
||||||
<Compile Include="Common\PerHelper.cs" />
|
<Compile Include="Common\PerHelper.cs" />
|
||||||
<Compile Include="Config.cs" />
|
<Compile Include="Config.cs" />
|
||||||
|
<Compile Include="Models\ModelTest.cs" />
|
||||||
|
<Compile Include="TestItems\TestOneToMany.cs" />
|
||||||
<Compile Include="TestItems\TestGetById.cs" />
|
<Compile Include="TestItems\TestGetById.cs" />
|
||||||
<Compile Include="TestItems\TestGetAll.cs" />
|
<Compile Include="TestItems\TestGetAll.cs" />
|
||||||
<Compile Include="Models\TestEntity.cs" />
|
<Compile Include="Models\TestEntity.cs" />
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using PerformanceTest.Models;
|
||||||
using PerformanceTest.TestItems;
|
using PerformanceTest.TestItems;
|
||||||
using SqlSugar;
|
using SqlSugar;
|
||||||
|
|
||||||
@ -16,10 +17,10 @@ namespace PerformanceTest
|
|||||||
/// <param name="args"></param>
|
/// <param name="args"></param>
|
||||||
static void Main(string[] args)
|
static void Main(string[] args)
|
||||||
{
|
{
|
||||||
InitData();
|
InitData();
|
||||||
|
|
||||||
var type = DemoType.GetById;
|
var type = DemoType.Like;
|
||||||
var ormType = OrmType.SqlSugar;
|
var ormType = OrmType.FREE;
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
case DemoType.GetAll:
|
case DemoType.GetAll:
|
||||||
@ -37,6 +38,9 @@ namespace PerformanceTest
|
|||||||
case DemoType.Like:
|
case DemoType.Like:
|
||||||
new TestLike().Init(ormType);
|
new TestLike().Init(ormType);
|
||||||
break;
|
break;
|
||||||
|
case DemoType.OnToN:
|
||||||
|
new TestOneToMany().Init(ormType);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -73,6 +77,16 @@ namespace PerformanceTest
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
conn.CodeFirst.InitTables<Group>();
|
||||||
|
conn.DbMaintenance.TruncateTable<Group>();
|
||||||
|
conn.CodeFirst.InitTables<User>();
|
||||||
|
conn.DbMaintenance.TruncateTable<User>();
|
||||||
|
//for (int i = 0; i < 1000; i++)
|
||||||
|
//{
|
||||||
|
// conn.Insertable(new Group { Id=i,Name=i+Guid.NewGuid().ToString() }).ExecuteCommand();
|
||||||
|
// conn.Insertable(new User() { AGroupId = i, Id = i + 1 }).ExecuteCommand();
|
||||||
|
// conn.Insertable(new User() { AGroupId = i, Id = i + 200000 }).ExecuteCommand();
|
||||||
|
//}
|
||||||
conn.Insertable(test).ExecuteCommand();
|
conn.Insertable(test).ExecuteCommand();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -82,7 +96,8 @@ namespace PerformanceTest
|
|||||||
GetById,
|
GetById,
|
||||||
GetSql,
|
GetSql,
|
||||||
Insert,
|
Insert,
|
||||||
Like
|
Like,
|
||||||
|
OnToN
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,14 +45,14 @@ namespace PerformanceTest.TestItems
|
|||||||
{
|
{
|
||||||
GC.Collect();//回收资源
|
GC.Collect();//回收资源
|
||||||
System.Threading.Thread.Sleep(1);//休息1秒
|
System.Threading.Thread.Sleep(1);//休息1秒
|
||||||
|
IFreeSql fsql = new FreeSql.FreeSqlBuilder()
|
||||||
|
.UseConnectionString(FreeSql.DataType.SqlServer, Config.connectionString)
|
||||||
|
.UseAutoSyncStructure(false) //自动同步实体结构到数据库
|
||||||
|
.Build();
|
||||||
PerHelper.Execute(eachCount, "Free like ", () =>
|
PerHelper.Execute(eachCount, "Free like ", () =>
|
||||||
{
|
{
|
||||||
IFreeSql fsql = new FreeSql.FreeSqlBuilder()
|
var x = "abc";
|
||||||
.UseConnectionString(FreeSql.DataType.SqlServer,Config.connectionString)
|
var list2 = fsql.Queryable<Test>().Where(it => it.F_String.Contains(x)).ToList();
|
||||||
.UseAutoSyncStructure(false) //自动同步实体结构到数据库
|
|
||||||
.Build();
|
|
||||||
var list2 = fsql.Queryable<Test>().Where(it => it.F_String.Contains("abc")).ToList();
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
93
Src/Asp.Net/PerformanceTest/TestItems/TestOneToMany.cs
Normal file
93
Src/Asp.Net/PerformanceTest/TestItems/TestOneToMany.cs
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
using Dapper.Contrib.Extensions;
|
||||||
|
using PerformanceTest.Models;
|
||||||
|
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 TestOneToMany
|
||||||
|
{
|
||||||
|
|
||||||
|
public void Init(OrmType type)
|
||||||
|
{
|
||||||
|
Database.SetInitializer<EFContext>(null);
|
||||||
|
Console.WriteLine("测试一次读取1条数据的速度");
|
||||||
|
var eachCount = 20;
|
||||||
|
|
||||||
|
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;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Console.Write("总计:"+(DateTime.Now-beginDate).TotalMilliseconds/1000.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void SqlSugar(int eachCount)
|
||||||
|
{
|
||||||
|
GC.Collect();//回收资源
|
||||||
|
System.Threading.Thread.Sleep(1);//休息1秒
|
||||||
|
|
||||||
|
PerHelper.Execute(eachCount, "SqlSugar", () =>
|
||||||
|
{
|
||||||
|
using (SqlSugarClient conn = Config.GetSugarConn())
|
||||||
|
{
|
||||||
|
conn.Aop.OnLogExecuted = (s, p) =>
|
||||||
|
{
|
||||||
|
Console.WriteLine(conn.Ado.SqlExecutionTime.TotalMilliseconds);
|
||||||
|
};
|
||||||
|
var list2 = conn.Queryable<PerformanceTest.Models2.Group>()
|
||||||
|
.Mapper(it => it.AUsers, it => it.AUsers.First().AGroupId).Where(it=>it.AUsers.Any()).ToList();
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
private static void Free(int eachCount)
|
||||||
|
{
|
||||||
|
GC.Collect();//回收资源
|
||||||
|
System.Threading.Thread.Sleep(1);//休息1秒
|
||||||
|
IFreeSql fsql = new FreeSql.FreeSqlBuilder()
|
||||||
|
.UseConnectionString(FreeSql.DataType.SqlServer, Config.connectionString)
|
||||||
|
.UseAutoSyncStructure(false) //自动同步实体结构到数据库
|
||||||
|
.Build();
|
||||||
|
PerHelper.Execute(eachCount, "free", () =>
|
||||||
|
{
|
||||||
|
|
||||||
|
var list2 = fsql.Queryable<Group>().IncludeMany(it => it.AUsers).Where(it=>it.AUsers.AsSelect().Any()).ToList();
|
||||||
|
//用.First(it=>it.Id==1)报错
|
||||||
|
});
|
||||||
|
}
|
||||||
|
private static void Dapper(int eachCount)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static void EF(int eachCount)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -4,8 +4,8 @@
|
|||||||
<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" version="2.0.105" targetFramework="net452" />
|
||||||
<package id="FreeSql.Provider.SqlServer" version="2.0.101" targetFramework="net452" />
|
<package id="FreeSql.Provider.SqlServer" version="2.0.105" 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.Common" version="4.3.0" targetFramework="net452" />
|
||||||
<package id="System.Data.SqlClient" version="4.8.2" targetFramework="net452" />
|
<package id="System.Data.SqlClient" version="4.8.2" targetFramework="net452" />
|
||||||
|
Loading…
Reference in New Issue
Block a user