mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-09-23 04:23:47 +08:00
Update .net core project
This commit is contained in:
@@ -10,10 +10,12 @@ namespace SqlSugar
|
|||||||
public partial class CodeFirstProvider : ICodeFirst
|
public partial class CodeFirstProvider : ICodeFirst
|
||||||
{
|
{
|
||||||
#region Properties
|
#region Properties
|
||||||
|
internal static object LockObject = new object();
|
||||||
public virtual SqlSugarProvider Context { get; set; }
|
public virtual SqlSugarProvider Context { get; set; }
|
||||||
protected bool IsBackupTable { get; set; }
|
protected bool IsBackupTable { get; set; }
|
||||||
protected int MaxBackupDataRows { get; set; }
|
protected int MaxBackupDataRows { get; set; }
|
||||||
protected virtual int DefultLength { get; set; }
|
protected virtual int DefultLength { get; set; }
|
||||||
|
protected Dictionary<Type, string> MappingTables = new Dictionary<Type, string>();
|
||||||
public CodeFirstProvider()
|
public CodeFirstProvider()
|
||||||
{
|
{
|
||||||
if (DefultLength == 0)
|
if (DefultLength == 0)
|
||||||
@@ -46,7 +48,10 @@ namespace SqlSugar
|
|||||||
|
|
||||||
public virtual void InitTables(Type entityType)
|
public virtual void InitTables(Type entityType)
|
||||||
{
|
{
|
||||||
|
//Prevent concurrent requests if used in your program
|
||||||
|
lock (CodeFirstProvider.LockObject)
|
||||||
|
{
|
||||||
|
MappingTableList oldTableList = CopyMappingTalbe();
|
||||||
//this.Context.Utilities.RemoveCacheAll();
|
//this.Context.Utilities.RemoveCacheAll();
|
||||||
this.Context.InitMappingInfoNoCache(entityType);
|
this.Context.InitMappingInfoNoCache(entityType);
|
||||||
if (!this.Context.DbMaintenance.IsAnySystemTablePermissions())
|
if (!this.Context.DbMaintenance.IsAnySystemTablePermissions())
|
||||||
@@ -68,7 +73,11 @@ namespace SqlSugar
|
|||||||
Execute(entityType);
|
Execute(entityType);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RestMappingTables(oldTableList);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public void InitTables<T>()
|
public void InitTables<T>()
|
||||||
{
|
{
|
||||||
InitTables(typeof(T));
|
InitTables(typeof(T));
|
||||||
@@ -107,6 +116,23 @@ namespace SqlSugar
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
public ICodeFirst As(Type type, string newTableName)
|
||||||
|
{
|
||||||
|
if (!MappingTables.ContainsKey(type))
|
||||||
|
{
|
||||||
|
MappingTables.Add(type,newTableName);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MappingTables[type]= newTableName;
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
public ICodeFirst As<T>(string newTableName)
|
||||||
|
{
|
||||||
|
return As(typeof(T),newTableName);
|
||||||
|
}
|
||||||
|
|
||||||
public virtual void InitTables(string entitiesNamespace)
|
public virtual void InitTables(string entitiesNamespace)
|
||||||
{
|
{
|
||||||
var types = Assembly.Load(entitiesNamespace).GetTypes();
|
var types = Assembly.Load(entitiesNamespace).GetTypes();
|
||||||
@@ -180,6 +206,11 @@ namespace SqlSugar
|
|||||||
protected virtual void Execute(Type entityType)
|
protected virtual void Execute(Type entityType)
|
||||||
{
|
{
|
||||||
var entityInfo = this.Context.EntityMaintenance.GetEntityInfoNoCache(entityType);
|
var entityInfo = this.Context.EntityMaintenance.GetEntityInfoNoCache(entityType);
|
||||||
|
if (this.MappingTables.ContainsKey(entityType))
|
||||||
|
{
|
||||||
|
entityInfo.DbTableName = this.MappingTables[entityType];
|
||||||
|
this.Context.MappingTables.Add(entityInfo.EntityName, entityInfo.DbTableName);
|
||||||
|
}
|
||||||
if (this.DefultLength > 0)
|
if (this.DefultLength > 0)
|
||||||
{
|
{
|
||||||
foreach (var item in entityInfo.Columns)
|
foreach (var item in entityInfo.Columns)
|
||||||
@@ -424,6 +455,28 @@ namespace SqlSugar
|
|||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Helper methods
|
#region Helper methods
|
||||||
|
private void RestMappingTables(MappingTableList oldTableList)
|
||||||
|
{
|
||||||
|
this.Context.MappingTables.Clear();
|
||||||
|
foreach (var table in oldTableList)
|
||||||
|
{
|
||||||
|
this.Context.MappingTables.Add(table.EntityName, table.DbTableName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private MappingTableList CopyMappingTalbe()
|
||||||
|
{
|
||||||
|
MappingTableList oldTableList = new MappingTableList();
|
||||||
|
if (this.Context.MappingTables == null)
|
||||||
|
{
|
||||||
|
this.Context.MappingTables = new MappingTableList();
|
||||||
|
}
|
||||||
|
foreach (var table in this.Context.MappingTables)
|
||||||
|
{
|
||||||
|
oldTableList.Add(table.EntityName, table.DbTableName);
|
||||||
|
}
|
||||||
|
return oldTableList;
|
||||||
|
}
|
||||||
|
|
||||||
public virtual string GetCreateTableString(EntityInfo entityInfo)
|
public virtual string GetCreateTableString(EntityInfo entityInfo)
|
||||||
{
|
{
|
||||||
StringBuilder result = new StringBuilder();
|
StringBuilder result = new StringBuilder();
|
||||||
|
@@ -9,6 +9,10 @@ namespace SqlSugar
|
|||||||
SqlSugarProvider Context { get; set; }
|
SqlSugarProvider Context { get; set; }
|
||||||
ICodeFirst BackupTable(int maxBackupDataRows = int.MaxValue);
|
ICodeFirst BackupTable(int maxBackupDataRows = int.MaxValue);
|
||||||
ICodeFirst SetStringDefaultLength(int length);
|
ICodeFirst SetStringDefaultLength(int length);
|
||||||
|
|
||||||
|
ICodeFirst As(Type type,string newTableName);
|
||||||
|
ICodeFirst As<T>(string newTableName);
|
||||||
|
|
||||||
void InitTables(string entitiesNamespace);
|
void InitTables(string entitiesNamespace);
|
||||||
void InitTables(string[] entitiesNamespaces);
|
void InitTables(string[] entitiesNamespaces);
|
||||||
void InitTables(params Type[] entityTypes);
|
void InitTables(params Type[] entityTypes);
|
||||||
|
Reference in New Issue
Block a user