Synchronization code

This commit is contained in:
sunkaixuan 2024-06-22 20:16:55 +08:00
parent 008892a1da
commit fe6c180433
3 changed files with 20 additions and 5 deletions

View File

@ -82,7 +82,7 @@ namespace SqlSugar
{
MappingTableList oldTableList = CopyMappingTalbe();
//this.Context.Utilities.RemoveCacheAll();
this.Context.InitMappingInfoNoCache(entityType);
var entityInfo=this.Context.GetEntityNoCacheInitMappingInfo(entityType);
if (!this.Context.DbMaintenance.IsAnySystemTablePermissions())
{
Check.Exception(true, "Dbfirst and Codefirst requires system table permissions");
@ -93,13 +93,13 @@ namespace SqlSugar
{
var executeResult = Context.Ado.UseTran(() =>
{
Execute(entityType);
Execute(entityType,entityInfo);
});
Check.Exception(!executeResult.IsSuccess, executeResult.ErrorMessage);
}
else
{
Execute(entityType);
Execute(entityType, entityInfo);
}
RestMappingTables(oldTableList);
@ -240,9 +240,9 @@ namespace SqlSugar
db.DbMaintenance.DropTable(tempTableName);
}
}
protected virtual void Execute(Type entityType)
protected virtual void Execute(Type entityType,EntityInfo entityInfo)
{
var entityInfo = this.Context.EntityMaintenance.GetEntityInfoNoCache(entityType);
//var entityInfo = this.Context.EntityMaintenance.GetEntityInfoNoCache(entityType);
if (entityInfo.Discrimator.HasValue())
{
Check.ExceptionEasy(!Regex.IsMatch(entityInfo.Discrimator, @"^(?:\w+:\w+)(?:,\w+:\w+)*$"), "The format should be type:cat for this type, and if there are multiple, it can be FieldName:cat,FieldName2:dog ", "格式错误应该是type:cat这种格式如果是多个可以FieldName:cat,FieldName2:dog不要有空格");

View File

@ -340,6 +340,7 @@ namespace SqlSugar
value = "empty";
}
}
value = GetDefaultValue(columnInfo, value);
var dt = new Dictionary<string, object>();
dt.Add(columnInfo.DbColumnName, value);
if (columnInfo.DataType.EqualCase("json") && columnInfo.DefaultValue?.Contains("}") == true)
@ -375,6 +376,14 @@ namespace SqlSugar
}
return true;
}
public virtual object GetDefaultValue(DbColumnInfo columnInfo, object value)
{
if (columnInfo.DataType.ObjToString().ToLower().IsIn("varchar", "nvarchar", "varchar2", "nvarchar2") && !string.IsNullOrEmpty(columnInfo.DefaultValue) && Regex.IsMatch(columnInfo.DefaultValue, @"^\w+$"))
{
value = columnInfo.DefaultValue;
}
return value;
}
public virtual bool UpdateColumn(string tableName, DbColumnInfo column)
{
tableName = this.SqlBuilder.GetTranslationTableName(tableName);

View File

@ -168,6 +168,12 @@ namespace SqlSugar
var entityInfo = this.Context.EntityMaintenance.GetEntityInfoNoCache(type);
InitMappingInfo(entityInfo);
}
public EntityInfo GetEntityNoCacheInitMappingInfo(Type type)
{
var entityInfo = this.Context.EntityMaintenance.GetEntityInfoNoCache(type);
InitMappingInfo(entityInfo);
return entityInfo;
}
//private EntityInfo CopyEntityInfo(EntityInfo entityInfo)
//{
// EntityInfo result = new EntityInfo()