Update exp to sql (string.format)

This commit is contained in:
sunkaixuan
2023-07-11 12:43:33 +08:00
parent b203a0a199
commit b382d5ca4b
2 changed files with 20 additions and 1 deletions

View File

@@ -562,8 +562,15 @@ namespace SqlSugar
{
var str = model.Args[0].MemberValue.ObjToString();
var array = model.Args.Skip(1).Select(it => it.IsMember ? it.MemberName : it.MemberValue).ToArray();
if (array.Length == 1 && array[0] is string[])
{
return string.Format("'" + str + "'", array[0] as string[]);
}
else
{
return string.Format("'" + str + "'", array);
}
}
public virtual string Format(MethodCallExpressionModel model)
{
@@ -573,6 +580,10 @@ namespace SqlSugar
{
return FormatConcat(model);
}
if (model.Args.Count == 2 && model.Args[1].MemberValue is string[])
{
return string.Format("" + str + "", model.Args[1].MemberValue as string[]);
}
str =Regex.Replace(str, @"(\{\d+?\})", revalue);
var array = model.Args.Skip(1).Select(it => it.IsMember?it.MemberName:(it.MemberValue==null?"''":it.MemberValue.ToSqlValue()))
.Select(it=>ToString(new MethodCallExpressionModel() { Args=new List<MethodCallExpressionArgs>() {

View File

@@ -366,6 +366,14 @@ namespace SqlSugar
{
parameter.CommonTempData = GetNewExpressionValue(item);
}
else if (name == "Format" && item is NewArrayExpression)
{
var exps = (item as NewArrayExpression).Expressions;
parameter.CommonTempData = exps.Select(it => {
var res = GetNewExpressionValue(ExpressionTool.RemoveConvert(it));
return res;
}).ToArray();
}
else
{
base.Start();