refactor(project): 根据最新组件重构代码

Longbow.Dat 2.3.0
Bootstrap.Security.DataAccess 2.2.0
PetaPoco.Compiled 6.0.403
PetaPoco.Extensions 1.0.4
增加BootstrapDataAccessConventionMapper适应BA数据库对应关系
This commit is contained in:
Argo Zhang 2019-05-11 12:12:16 +08:00
parent 3800ffc98a
commit e96192bded
6 changed files with 58 additions and 6 deletions

View File

@ -11,9 +11,9 @@
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Bootstrap.Security.DataAccess" Version="2.1.0" /> <PackageReference Include="Bootstrap.Security.DataAccess" Version="2.2.0" />
<PackageReference Include="Longbow.Cache" Version="2.2.9" /> <PackageReference Include="Longbow.Cache" Version="2.2.9" />
<PackageReference Include="Longbow.Data" Version="2.2.8" /> <PackageReference Include="Longbow.Data" Version="2.3.0" />
<PackageReference Include="Longbow.Web" Version="2.2.11" /> <PackageReference Include="Longbow.Web" Version="2.2.11" />
<PackageReference Include="Microsoft.Data.Sqlite" Version="2.2.4" /> <PackageReference Include="Microsoft.Data.Sqlite" Version="2.2.4" />
</ItemGroup> </ItemGroup>

View File

@ -1,5 +1,5 @@
using Bootstrap.Security.DataAccess; using Bootstrap.Security.DataAccess;
using Longbow.Data; using PetaPoco;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;

View File

@ -11,14 +11,15 @@
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="Bootstrap.Security.DataAccess" Version="2.1.0" /> <PackageReference Include="Bootstrap.Security.DataAccess" Version="2.2.0" />
<PackageReference Include="Longbow.Data" Version="2.2.8" /> <PackageReference Include="Longbow.Data" Version="2.3.0" />
<PackageReference Include="Longbow.Logging" Version="2.2.6" /> <PackageReference Include="Longbow.Logging" Version="2.2.6" />
<PackageReference Include="Longbow.Security.Cryptography" Version="1.3.0" /> <PackageReference Include="Longbow.Security.Cryptography" Version="1.3.0" />
<PackageReference Include="Longbow.Web" Version="2.2.11" /> <PackageReference Include="Longbow.Web" Version="2.2.11" />
<PackageReference Include="Longbow.Cache" Version="2.2.9" /> <PackageReference Include="Longbow.Cache" Version="2.2.9" />
<PackageReference Include="Longbow" Version="2.2.9" /> <PackageReference Include="Longbow" Version="2.2.9" />
<PackageReference Include="Microsoft.Data.Sqlite" Version="2.2.4" /> <PackageReference Include="Microsoft.Data.Sqlite" Version="2.2.4" />
<PackageReference Include="PetaPoco.Extensions" Version="1.0.4" />
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@ -0,0 +1,50 @@
using PetaPoco;
using System;
using System.Reflection;
namespace Bootstrap.DataAccess
{
internal class BootstrapDataAccessConventionMapper : IMapper
{
private readonly IMapper _mapper;
public BootstrapDataAccessConventionMapper()
{
_mapper = new ConventionMapper();
}
/// <summary>
///
/// </summary>
/// <param name="pocoProperty"></param>
/// <returns></returns>
public ColumnInfo GetColumnInfo(PropertyInfo pocoProperty) => _mapper.GetColumnInfo(pocoProperty);
/// <summary>
///
/// </summary>
/// <param name="targetProperty"></param>
/// <param name="sourceType"></param>
/// <returns></returns>
public Func<object, object> GetFromDbConverter(PropertyInfo targetProperty, Type sourceType) => _mapper.GetFromDbConverter(targetProperty, sourceType);
/// <summary>
///
/// </summary>
/// <param name="pocoType"></param>
/// <returns></returns>
public TableInfo GetTableInfo(Type pocoType)
{
var ti = _mapper.GetTableInfo(pocoType);
ti.AutoIncrement = true;
return ti;
}
/// <summary>
///
/// </summary>
/// <param name="sourceProperty"></param>
/// <returns></returns>
public Func<object, object> GetToDbConverter(PropertyInfo sourceProperty) => _mapper.GetToDbConverter(sourceProperty);
}
}

View File

@ -16,6 +16,7 @@ namespace Bootstrap.DataAccess
/// <returns></returns> /// <returns></returns>
public static IDatabase Create(string connectionName = null, bool keepAlive = false) public static IDatabase Create(string connectionName = null, bool keepAlive = false)
{ {
if (Mappers.GetMapper(typeof(Exceptions), null) == null) Mappers.Register(typeof(Exceptions).Assembly, new BootstrapDataAccessConventionMapper());
var db = Longbow.Data.DbManager.Create(connectionName, keepAlive); var db = Longbow.Data.DbManager.Create(connectionName, keepAlive);
db.ExceptionThrown += (sender, args) => args.Exception.Log(new NameValueCollection() { ["LastCmd"] = db.LastCommand }); db.ExceptionThrown += (sender, args) => args.Exception.Log(new NameValueCollection() { ["LastCmd"] = db.LastCommand });
return db; return db;

View File

@ -1,6 +1,6 @@
using Bootstrap.Security; using Bootstrap.Security;
using Bootstrap.Security.DataAccess; using Bootstrap.Security.DataAccess;
using Longbow.Data; using PetaPoco;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;