Update .net core project

This commit is contained in:
sunkaixuan 2022-08-06 00:08:26 +08:00
parent 19e4bbddaa
commit e93f056230
8 changed files with 37 additions and 5 deletions

View File

@ -221,12 +221,19 @@ namespace SqlSugar
var dtColumInfo = dtColums.First(it => it.ColumnName.EqualCase(columnInfo.DbColumnName)); var dtColumInfo = dtColums.First(it => it.ColumnName.EqualCase(columnInfo.DbColumnName));
var type = UtilMethods.GetUnderType(dtColumInfo.DataType); var type = UtilMethods.GetUnderType(dtColumInfo.DataType);
var value= type==UtilConstants.StringType?(object)"": Activator.CreateInstance(type); var value= type==UtilConstants.StringType?(object)"": Activator.CreateInstance(type);
if (this.Context.CurrentConnectionConfig.DbType == DbType.Oracle)
{
value = columnInfo.DefaultValue;
if (value.Equals(""))
{
value = "empty";
}
}
var dt = new Dictionary<string, object>(); var dt = new Dictionary<string, object>();
dt.Add(columnInfo.DbColumnName, value); dt.Add(columnInfo.DbColumnName, value);
this.Context.Updateable(dt) this.Context.Updateable(dt)
.AS(tableName) .AS(tableName)
.Where($"{columnInfo.DbColumnName} is null ").ExecuteCommand(); .Where($"{columnInfo.DbColumnName} is null ").ExecuteCommand();
if(this.Context.CurrentConnectionConfig.DbType!=DbType.Oracle)
columnInfo.IsNullable = false; columnInfo.IsNullable = false;
UpdateColumn(tableName, columnInfo); UpdateColumn(tableName, columnInfo);
} }

View File

@ -327,6 +327,7 @@ namespace SqlSugar
{ {
var sqlObj = GetWhereSql(navObjectNameColumnInfo.Navigat.Name); var sqlObj = GetWhereSql(navObjectNameColumnInfo.Navigat.Name);
var navList = selector(this.Context.Queryable<object>().AS(navEntityInfo.DbTableName) var navList = selector(this.Context.Queryable<object>().AS(navEntityInfo.DbTableName)
.WhereIF(navObjectNameColumnInfo.Navigat.WhereSql.HasValue(), navObjectNameColumnInfo.Navigat.WhereSql)
.WhereIF(sqlObj.WhereString.HasValue(),sqlObj.WhereString) .WhereIF(sqlObj.WhereString.HasValue(),sqlObj.WhereString)
.AddParameters(sqlObj.Parameters).Where(conditionalModels)); .AddParameters(sqlObj.Parameters).Where(conditionalModels));
var groupQuery = (from l in list var groupQuery = (from l in list

View File

@ -228,6 +228,7 @@ namespace SqlSugar
public string MappingAId { get; set; } public string MappingAId { get; set; }
public string MappingBId { get; set; } public string MappingBId { get; set; }
public NavigateType NavigatType { get; set; } public NavigateType NavigatType { get; set; }
public string WhereSql { get; set; }
public Navigate(NavigateType navigatType,string name) public Navigate(NavigateType navigatType,string name)
{ {
this.Name = name; this.Name = name;
@ -239,6 +240,16 @@ namespace SqlSugar
this.Name2 = lastName; this.Name2 = lastName;
this.NavigatType = navigatType; this.NavigatType = navigatType;
} }
public Navigate(NavigateType navigatType, string firstName, string lastName,string whereSql)
{
this.Name = firstName;
this.Name2 = lastName;
this.NavigatType = navigatType;
this.WhereSql = whereSql;
Check.ExceptionEasy(navigatType != NavigateType.OneToOne, "Currently, only one-to-one navigation configuration Sql conditions are supported", "目前导航配置Sql条件只支持一对一");
}
public Navigate(Type MappingTableType,string typeAiD,string typeBId) public Navigate(Type MappingTableType,string typeAiD,string typeBId)
{ {
this.MappingType = MappingTableType; this.MappingType = MappingTableType;

View File

@ -12,11 +12,11 @@ namespace SqlSugar
{ {
if (model.Args.Count == 1) if (model.Args.Count == 1)
{ {
return $"row_number() over(order by {model.Args[0].MemberName})"; return $"row_number() over(order by {model.Args[0].MemberName.ObjToString().TrimEnd('\'').TrimStart('\'')})";
} }
else else
{ {
return $"row_number() over( partition by {model.Args[1].MemberName} order by {model.Args[0].MemberName})"; return $"row_number() over( partition by {model.Args[1].MemberName.ObjToString().TrimEnd('\'').TrimStart('\'')} order by {model.Args[0].MemberName.ObjToString().TrimEnd('\'').TrimStart('\'')})";
} }
} }
public virtual string RowCount(MethodCallExpressionModel model) public virtual string RowCount(MethodCallExpressionModel model)

View File

@ -178,7 +178,11 @@ namespace SqlSugar
{ {
var mappingInfo = this.MappingTables.FirstOrDefault(it => it.EntityName.Equals(entityName, StringComparison.CurrentCultureIgnoreCase)); var mappingInfo = this.MappingTables.FirstOrDefault(it => it.EntityName.Equals(entityName, StringComparison.CurrentCultureIgnoreCase));
var name = (mappingInfo == null ? entityName : mappingInfo.DbTableName); var name = (mappingInfo == null ? entityName : mappingInfo.DbTableName);
if (name.Contains(".")) if (name.Contains(SqlTranslationLeft) && name.Contains(SqlTranslationRight))
{
return name;
}
else if (name.Contains("."))
{ {
return string.Join(".", name.Split('.').Select(it => SqlTranslationLeft + it + SqlTranslationRight)); return string.Join(".", name.Split('.').Select(it => SqlTranslationLeft + it + SqlTranslationRight));
} }

View File

@ -98,6 +98,7 @@ namespace SqlSugar
selectName = queryable.QueryBuilder.Builder.GetTranslationColumnName(selectName); selectName = queryable.QueryBuilder.Builder.GetTranslationColumnName(selectName);
mapper.Sql = queryable mapper.Sql = queryable
.AS(this.ProPertyEntity.DbTableName) .AS(this.ProPertyEntity.DbTableName)
.WhereIF(Navigat.WhereSql.HasValue(),Navigat.WhereSql)
.Where($" {ShorName}.{name}={pk} ").Select(selectName).ToSql().Key; .Where($" {ShorName}.{name}={pk} ").Select(selectName).ToSql().Key;
mapper.Sql = $" ({mapper.Sql}) "; mapper.Sql = $" ({mapper.Sql}) ";
return mapper; return mapper;

View File

@ -66,6 +66,10 @@ namespace SqlSugar
var navColum = item.ParentEntityInfo.Columns.FirstOrDefault(it => it.PropertyName == item.Nav.Name); var navColum = item.ParentEntityInfo.Columns.FirstOrDefault(it => it.PropertyName == item.Nav.Name);
Check.ExceptionEasy(pkColumn == null, $"{item.ThisEntityInfo.EntityName} need PrimayKey", $"使用导航属性{item.ThisEntityInfo.EntityName} 缺少主键"); Check.ExceptionEasy(pkColumn == null, $"{item.ThisEntityInfo.EntityName} need PrimayKey", $"使用导航属性{item.ThisEntityInfo.EntityName} 缺少主键");
var on = $" {ToShortName(shortName)}.{queryable.SqlBuilder.GetTranslationColumnName(pkColumn.DbColumnName)}={ToShortName(formInfo.ThisEntityInfo.DbTableName + (i - 1))}.{queryable.SqlBuilder.GetTranslationColumnName(navColum.DbColumnName)}"; var on = $" {ToShortName(shortName)}.{queryable.SqlBuilder.GetTranslationColumnName(pkColumn.DbColumnName)}={ToShortName(formInfo.ThisEntityInfo.DbTableName + (i - 1))}.{queryable.SqlBuilder.GetTranslationColumnName(navColum.DbColumnName)}";
if (item.Nav.WhereSql.HasValue())
{
on = (on + " AND " + item.Nav.WhereSql);
}
queryable.AddJoinInfo(item.ThisEntityInfo.DbTableName,ToShortName(shortName), on, JoinType.Inner); queryable.AddJoinInfo(item.ThisEntityInfo.DbTableName,ToShortName(shortName), on, JoinType.Inner);
++i; ++i;
lastShortName = shortName; lastShortName = shortName;

View File

@ -589,6 +589,10 @@ namespace SqlSugar
{ {
return Convert.ToInt32(item.FieldValue); return Convert.ToInt32(item.FieldValue);
} }
else if (item.FieldValue!=null&&item.CSharpTypeName.EqualCase(UtilConstants.BoolType.Name))
{
return Convert.ToBoolean(item.FieldValue.ToLower());
}
else if (item.CSharpTypeName.EqualCase(UtilConstants.LongType.Name)) else if (item.CSharpTypeName.EqualCase(UtilConstants.LongType.Name))
{ {
return Convert.ToInt64(item.FieldValue); return Convert.ToInt64(item.FieldValue);