using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; using System.Text; using System.Text.RegularExpressions; namespace SqlSugar { public class MemberExpressionResolve : BaseResolve { public ExpressionParameter Parameter { get; set; } public MemberExpressionResolve(ExpressionParameter parameter) : base(parameter) { ExpressionParameter baseParameter; MemberExpression expression; bool? isLeft; bool isSetTempData, isValue, isValueBool, isLength, isDateValue, isHasValue, isDateDate, isMemberValue, isSingle, fieldIsBool, isSelectField, isField; SettingParameters(parameter, out baseParameter, out expression, out isLeft, out isSetTempData, out isValue, out isValueBool, out isLength, out isDateValue, out isHasValue, out isDateDate, out isMemberValue, out isSingle, out fieldIsBool, out isSelectField, out isField); baseParameter.ChildExpression = expression; ProcessNavigationMemberAndUpdateExpression(ref expression, ref isValue); if (isLength) { ResolveLength(parameter, isLeft, expression); } else if (IsDateDiff(expression)) { ResolveDateDiff(parameter, isLeft, expression); } else if (expression.Member.Name == "DayOfWeek" && expression.Type == typeof(DayOfWeek)) { ResolveDayOfWeek(parameter, isLeft, expression); } else if (isHasValue) { ResolveHasValue(parameter, expression); } else if (isDateValue) { ResolveDateValue(parameter, isLeft, expression); } else if (isValueBool) { ResolveValueBool(parameter, baseParameter, expression, isLeft, isSingle); } else if (isValue && expression.Expression != null && expression.Expression is MethodCallExpression) { ResolveCallValue(parameter, baseParameter, expression, isLeft, isSetTempData, isSingle); } else if (isValue & IsNavValue(expression)) { expression = expression.Expression as MemberExpression; ResolveMemberValue(parameter, baseParameter, expression, isLeft, isSetTempData); } else if (isValue) { ResolveValue(parameter, baseParameter, expression, isLeft, isSetTempData, isSingle); } else if (expression.Expression != null && expression.Expression.Type == UtilConstants.DateType && expression is MemberExpression && expression.Expression is MethodCallExpression) { ResolveDateDateByCall(parameter, isLeft, expression); } else if (isDateDate) { ResolveDateDate(parameter, isLeft, expression); } else if (IsConvertMemberName(expression)) { ResolveConvertMemberName(parameter, expression, isLeft); } else if (isMemberValue) { ResolveMemberValue(parameter, baseParameter, expression, isLeft, isSetTempData); } else if (fieldIsBool && !isField && !isSelectField) { ResolvefieldIsBool(parameter, baseParameter, isLeft, isSetTempData, expression, isSingle); } else { ResolveDefault(parameter, baseParameter, expression, isLeft, isSetTempData, isSingle); } } private void ProcessNavigationMemberAndUpdateExpression(ref MemberExpression expression, ref bool isValue) { if (isValue && expression.Expression is MemberExpression childMemExp) { if (childMemExp.Expression is MemberExpression navMemExp) { if (ExpressionTool.IsNavMember(this.Context, navMemExp)) { expression = childMemExp; isValue = false; } } } } #region Navigate private static bool IsNavValue(MemberExpression expression) { var isDateMember = expression.Type == UtilConstants.DateType && expression.Expression is MemberExpression; return isDateMember && (expression.Expression as MemberExpression)?.Expression is MemberExpression; } private void DefaultOneToOneN(ExpressionParameter parameter, ExpressionParameter baseParameter, bool? isLeft, bool isSetTempData, OneToOneNavgateExpressionN navN) { var value = navN.GetMemberSql(); SetNavigateResult(); this.Context.SingleTableNameSubqueryShortName = navN.shorName; if (isSetTempData) { baseParameter.CommonTempData = value; } else { AppendValue(parameter, isLeft, value); } } private void DefaultOneToOne(ExpressionParameter parameter, ExpressionParameter baseParameter, bool? isLeft, bool isSetTempData, OneToOneNavgateExpression nav) { var value = nav.GetSql(); SetNavigateResult(); this.Context.SingleTableNameSubqueryShortName = nav.ShorName; if (isSetTempData) { baseParameter.CommonTempData = value; } else { AppendValue(parameter, isLeft, value); } } #endregion #region Resolve default private void ResolveDefault(ExpressionParameter parameter, ExpressionParameter baseParameter, MemberExpression expression, bool? isLeft, bool isSetTempData, bool isSingle) { string fieldName = string.Empty; switch (parameter.Context.ResolveType) { case ResolveExpressType.Update: case ResolveExpressType.SelectSingle: fieldName = GetSingleName(parameter, expression, isLeft); if (isSetTempData) baseParameter.CommonTempData = fieldName; else base.Context.Result.Append(fieldName); break; case ResolveExpressType.SelectMultiple: fieldName = GetMultipleName(parameter, expression, isLeft); if (isSetTempData) baseParameter.CommonTempData = fieldName; else base.Context.Result.Append(fieldName); break; case ResolveExpressType.WhereSingle: case ResolveExpressType.WhereMultiple: ResolveWhereLogic(parameter, baseParameter, expression, isLeft, isSetTempData, isSingle); break; case ResolveExpressType.FieldSingle: fieldName = GetSingleName(parameter, expression, isLeft); var fieldIsCommonTemp = IsFieldIsCommonTemp(isSetTempData,parameter); if (fieldIsCommonTemp) { baseParameter.CommonTempData = fieldName; } else { base.Context.Result.Append(fieldName); } break; case ResolveExpressType.FieldMultiple: fieldName = GetMultipleName(parameter, expression, isLeft); var fieldIsCommonTemp2= IsFieldIsCommonTemp(isSetTempData, parameter); if(fieldIsCommonTemp2) { baseParameter.CommonTempData = fieldName; } else { base.Context.Result.Append(fieldName); } break; case ResolveExpressType.ArrayMultiple: case ResolveExpressType.ArraySingle: fieldName = GetName(parameter, expression, isLeft, parameter.Context.ResolveType == ResolveExpressType.ArraySingle); var fieldIsCommonTemp3 = IsFieldIsCommonTemp(isSetTempData, parameter); if (fieldIsCommonTemp3) { baseParameter.CommonTempData = fieldName; } else { base.Context.Result.Append(fieldName); } break; default: break; } } private bool IsFieldIsCommonTemp(bool isSetTempData, ExpressionParameter parameter) { if (parameter.BaseParameter == null) return false; var childExpression= parameter.BaseParameter.ChildExpression.ObjToString(); var expression=parameter.BaseParameter.CurrentExpression.ObjToString(); var datevaluelist = UtilConstants.DateTypeStringList.Select(it => childExpression+"." + it); return isSetTempData&& datevaluelist.Contains(expression); } #endregion #region Resolve Where private void ResolveBoolLogic(ExpressionParameter parameter, ExpressionParameter baseParameter, MemberExpression expression, bool? isLeft, bool isSetTempData, bool isSingle) { string fieldName = string.Empty; if (isSetTempData) { if (ExpressionTool.IsConstExpression(expression)) { var value = ExpressionTool.GetMemberValue(expression.Member, expression); baseParameter.CommonTempData = value + "=1 "; } else { fieldName = GetName(parameter, expression, null, isSingle); baseParameter.CommonTempData = fieldName + "=1 "; } } else { if (ExpressionTool.IsConstExpression(expression)) { var value = ExpressionTool.GetMemberValue(expression.Member, expression); base.AppendValue(parameter, isLeft, value + "=1 "); } else { fieldName = GetName(parameter, expression, isLeft, isSingle); AppendMember(parameter, isLeft, fieldName + "=1 "); } } } private void ResolveWhereLogic(ExpressionParameter parameter, ExpressionParameter baseParameter, MemberExpression expression, bool? isLeft, bool isSetTempData, bool isSingle) { string fieldName = string.Empty; if (isSetTempData) { if (ExpressionTool.IsConstExpression(expression)) { var value = ExpressionTool.GetMemberValue(expression.Member, expression); baseParameter.CommonTempData = value; } else { fieldName = GetName(parameter, expression, null, isSingle); baseParameter.CommonTempData = fieldName; } } else { if (ExpressionTool.IsConstExpression(expression)) { var value = ExpressionTool.GetMemberValue(expression.Member, expression); base.AppendValue(parameter, isLeft, value); } else { fieldName = GetName(parameter, expression, isLeft, isSingle); AppendMember(parameter, isLeft, fieldName); } } } #endregion #region Resolve special member private void ResolveMemberValue(ExpressionParameter parameter, ExpressionParameter baseParameter, MemberExpression expression, bool? isLeft, bool isSetTempData) { var nav = new OneToOneNavgateExpression(this.Context?.SugarContext?.Context,this); nav.ExpContext = this.Context; var navN = new OneToOneNavgateExpressionN(this.Context?.SugarContext?.Context); if (nav.IsNavgate(expression)) { if (this.Context?.SugarContext?.QueryBuilder?.JoinQueryInfos != null) { var p = expression.Expression.ObjToString(); var querybuilder = this.Context?.SugarContext?.QueryBuilder; var joinInfos = querybuilder.JoinQueryInfos; var joinInfo = joinInfos.FirstOrDefault(it => $"{querybuilder.TableShortName}.{it.ShortName.Replace("pnv_", "")}" == p); if (joinInfo != null) { var columnInfo = nav.ProPertyEntity.Columns.FirstOrDefault(it => it.PropertyName == nav.MemberName); var value = new MapperSql() { Sql = querybuilder.Builder.GetTranslationColumnName(joinInfo.ShortName) + "." + querybuilder.Builder.GetTranslationColumnName(columnInfo.DbColumnName) }; if (isSetTempData) { baseParameter.CommonTempData = value; } else { AppendValue(parameter, isLeft, value); } } else { DefaultOneToOne(parameter, baseParameter, isLeft, isSetTempData, nav); } } else { DefaultOneToOne(parameter, baseParameter, isLeft, isSetTempData, nav); } } else if (navN.IsNavgate(expression)) { DefaultOneToOneN(parameter, baseParameter, isLeft, isSetTempData, navN); } else { ResolveMemberValue(parameter, baseParameter, isLeft, isSetTempData, expression); } } private void ResolveConvertMemberName(ExpressionParameter parameter, MemberExpression expression, bool? isLeft) { var memParameter = (expression.Expression as UnaryExpression).Operand as ParameterExpression; var name = ExpressionTool.GetMemberName(expression); if (this.Context.IsSingle) { AppendMember(parameter, isLeft, this.Context.GetTranslationColumnName(name)); } else { AppendMember(parameter, isLeft, this.Context.GetTranslationColumnName(memParameter.Name + "." + name)); } } private void ResolveDayOfWeek(ExpressionParameter parameter, bool? isLeft, MemberExpression expression) { var exp = expression.Expression; var value = GetNewExpressionValue(exp); var result = this.Context.DbMehtods.DateValue(new MethodCallExpressionModel() { Args = new List() { new MethodCallExpressionArgs(){ MemberName=value, MemberValue=value }, new MethodCallExpressionArgs(){ MemberName=DateType.Weekday, MemberValue=DateType.Weekday } } }); ; base.AppendMember(parameter, isLeft, result); } private void ResolveDateDiff(ExpressionParameter parameter, bool? isLeft, MemberExpression expression) { var binaryExp=expression.Expression as BinaryExpression; var beginExp = binaryExp.Right; var endExp = binaryExp.Left; var dateType = DateType.Day; var begin = GetNewExpressionValue(beginExp); var end = GetNewExpressionValue(endExp); foreach (var item in UtilMethods.EnumToDictionary()) { if (expression.Member.Name.ToLower().Contains(item.Key.ToLower())) { dateType = item.Value; break; } } var result = this.Context.DbMehtods.DateDiff(new MethodCallExpressionModel() { Args = new List() { new MethodCallExpressionArgs(){ MemberName=dateType, MemberValue=dateType }, new MethodCallExpressionArgs(){ MemberName=begin, MemberValue=begin }, new MethodCallExpressionArgs(){ MemberName=end, MemberValue=end } } }); ; base.AppendMember(parameter, isLeft, result); } private void ResolveDateDateByCall(ExpressionParameter parameter, bool? isLeft, MemberExpression expression) { var value = GetNewExpressionValue(expression.Expression); if (expression.Member.Name == "Date") { AppendMember(parameter, isLeft, GetToDateShort(value)); } else { foreach (int myCode in Enum.GetValues(typeof(DateType))) { string strName = Enum.GetName(typeof(DateType), myCode);//获取名称 if (expression.Member.Name == strName) { AppendMember(parameter, isLeft, this.Context.DbMehtods.MergeString(this.GetDateValue(value, (DateType)(myCode)))); } } } } private void ResolveCallValue(ExpressionParameter parameter, ExpressionParameter baseParameter, MemberExpression expression, bool? isLeft, bool isSetTempData, bool isSingle) { try { baseParameter.ChildExpression = expression; string fieldName = string.Empty; if (isSetTempData) { var value = ExpressionTool.DynamicInvoke(expression); baseParameter.CommonTempData = value; } else { var value = ExpressionTool.DynamicInvoke(expression); base.AppendValue(parameter, isLeft, value); } } catch { Check.Exception(true, "Not Support {0}", expression.ToString()); } } private MemberExpression ResolveValue(ExpressionParameter parameter, ExpressionParameter baseParameter, MemberExpression expression, bool? isLeft, bool isSetTempData, bool isSingle) { expression = expression.Expression as MemberExpression; baseParameter.ChildExpression = expression; if (UtilMethods.GetUnderType(expression.Type) == UtilConstants.BoolType && parameter.BaseExpression != null && ExpressionTool.IsLogicOperator(parameter.BaseExpression)) { ResolveBoolLogic(parameter, baseParameter, expression, isLeft, isSetTempData, isSingle); } else { ResolveWhereLogic(parameter, baseParameter, expression, isLeft, isSetTempData, isSingle); } return expression; } private void ResolveValueBool(ExpressionParameter parameter, ExpressionParameter baseParameter, MemberExpression expression, bool? isLeft, bool isSingle) { string fieldName = GetName(parameter, expression.Expression as MemberExpression, isLeft, isSingle); if (expression.Type == UtilConstants.BoolType && baseParameter.OperatorValue.IsNullOrEmpty()) { fieldName = this.Context.DbMehtods.EqualTrue(fieldName); } AppendMember(parameter, isLeft, fieldName); } private void ResolveMemberValue(ExpressionParameter parameter, ExpressionParameter baseParameter, bool? isLeft, bool isSetTempData, MemberExpression expression) { if (ExpressionTool.IsOwnsOne(this.Context, expression)) { var column = ExpressionTool.GetOwnsOneColumnInfo(this.Context, expression); var columnName = column.DbColumnName; if (this.Context.IsJoin) { var expParameterInfo = ExpressionTool.GetParameters(expression).First(); columnName = $"{expParameterInfo.Name}.{columnName}"; } columnName=this.Context.GetTranslationColumnName(columnName); if (isSetTempData) { baseParameter.CommonTempData = columnName; } else { AppendMember(parameter, isLeft, columnName); } return; } var value = ExpressionTool.GetMemberValue(expression.Member, expression); if (isSetTempData) { if (value is MapperSql) { value = (value as MapperSql).Sql; } baseParameter.CommonTempData = value; } else { if (parameter?.OppsiteExpression != null) { var exp = ExpressionTool.RemoveConvert(parameter?.OppsiteExpression); if (exp is MemberExpression) { var member = (exp as MemberExpression); var memberParent = member.Expression; if (memberParent != null && this.Context?.SugarContext?.Context != null) { var entity = this.Context.SugarContext.Context.EntityMaintenance.GetEntityInfo(memberParent.Type); var columnInfo = entity.Columns.FirstOrDefault(it => it.PropertyName == member.Member.Name); if (columnInfo?.SqlParameterDbType is Type) { var type = columnInfo.SqlParameterDbType as Type; var ParameterConverter = type.GetMethod("ParameterConverter").MakeGenericMethod(columnInfo.PropertyInfo.PropertyType); var obj = Activator.CreateInstance(type); var p = ParameterConverter.Invoke(obj, new object[] { value, 100 + this.ContentIndex }) as SugarParameter; value = p.Value; } } } } AppendValue(parameter, isLeft, value); } } private void ResolvefieldIsBool(ExpressionParameter parameter, ExpressionParameter baseParameter, bool? isLeft, bool isSetTempData, MemberExpression expression, bool isSingle) { var fieldName = GetName(parameter, expression, isLeft, isSingle); if (isSetTempData) { baseParameter.CommonTempData = fieldName; } else { fieldName = this.Context.DbMehtods.EqualTrue(fieldName.ObjToString()); AppendMember(parameter, isLeft, fieldName); } } private void ResolveDateDate(ExpressionParameter parameter, bool? isLeft, MemberExpression expression) { var name = expression.Member.Name; var oldCommonTempDate = parameter.CommonTempData; parameter.CommonTempData = CommonTempDataType.Result; this.Expression = expression.Expression; this.Start(); var isConst = parameter.CommonTempData.GetType() == UtilConstants.DateType; if (isConst) { if (this.Context?.Case?.IsDateString==true) { AppendMember(parameter, isLeft, GetToDateShort("'" + parameter.CommonTempData.ObjToDate().Date.ToString("yyyy-MM-dd") + "'")); } else { AppendValue(parameter, isLeft, parameter.CommonTempData.ObjToDate().Date); } } else { var GetYear = new MethodCallExpressionModel() { Args = new List() { new MethodCallExpressionArgs() { IsMember=true, MemberName=parameter.CommonTempData, MemberValue=parameter.CommonTempData }, new MethodCallExpressionArgs() { MemberName=DateType.Year, MemberValue=DateType.Year} } }; if (parameter.CommonTempData is MapperSql) { parameter.CommonTempData = ((MapperSql)parameter.CommonTempData).Sql; } AppendMember(parameter, isLeft, GetToDateShort(parameter.CommonTempData.ObjToString())); } parameter.CommonTempData = oldCommonTempDate; } private void ResolveDateValue(ExpressionParameter parameter, bool? isLeft, MemberExpression expression) { var name = expression.Member.Name; var oldCommonTempDate = parameter.CommonTempData; parameter.CommonTempData = CommonTempDataType.Result; this.Expression = expression.Expression; var isConst = this.Expression is ConstantExpression; var isDateTimeNowDateStartWith = expression.ObjToString().StartsWith("DateTime.Now.Date."); var isDateContains = expression.ObjToString().Contains(".Date."); if (this.Expression.Type == UtilConstants.DateType && this.Expression.ToString() == "DateTime.Now") { this.Expression = expression; var parameterName = base.AppendParameter(ExpressionTool.GetMemberValue(expression.Member, expression)); base.AppendMember(parameter, isLeft, parameterName); } else if (isDateTimeNowDateStartWith) { this.Expression = expression; var parameterName = base.AppendParameter(ExpressionTool.GetMemberValue(expression.Member, expression)); base.AppendMember(parameter, isLeft, parameterName); } else if (isDateContains) { parameter.CommonTempData = base.GetNewExpressionValue(this.Expression); var result = this.Context.DbMehtods.DateValue(new MethodCallExpressionModel() { Conext=this.Context, Args = new List() { new MethodCallExpressionArgs() { IsMember = !isConst, MemberName = parameter.CommonTempData, MemberValue = null }, new MethodCallExpressionArgs() { IsMember = true, MemberName = name, MemberValue = name } } }); base.AppendMember(parameter, isLeft, result); } else { this.Start(); if(parameter.CommonTempData!=null&& parameter.CommonTempData is DateTime) { parameter.CommonTempData= base.AppendParameter(parameter.CommonTempData); } else if (parameter.CommonTempData != null && parameter.CommonTempData?.GetType()?.FullName=="System.DateOnly") { parameter.CommonTempData = base.AppendParameter(parameter.CommonTempData); } var result = this.Context.DbMehtods.DateValue(new MethodCallExpressionModel() { Conext=this.Context, Args = new List() { new MethodCallExpressionArgs() { IsMember = !isConst, MemberName = parameter.CommonTempData, MemberValue = null }, new MethodCallExpressionArgs() { IsMember = true, MemberName = name, MemberValue = name } } }); base.AppendMember(parameter, isLeft, result); } parameter.CommonTempData = oldCommonTempDate; } private void ResolveHasValue(ExpressionParameter parameter, MemberExpression expression) { parameter.CommonTempData = CommonTempDataType.Result; this.Expression = expression.Expression; this.Start(); var methodParamter = new MethodCallExpressionArgs() { IsMember = true, MemberName = parameter.CommonTempData, MemberValue = null }; if (expression.Expression?.Type != null) { methodParamter.Type = UtilMethods.GetUnderType(expression.Expression?.Type); } var result = this.Context.DbMehtods.HasValue(new MethodCallExpressionModel() { Args = new List() { methodParamter } }); if (parameter.BaseExpression != null && ExpressionTool.IsLogicOperator(parameter.BaseExpression) && parameter.IsLeft == true) { if (base.Context.Result.Contains(ExpressionConst.FormatSymbol)) { base.Context.Result.Replace(ExpressionConst.FormatSymbol, ""); } this.Context.Result.Append(result + " " + ExpressionTool.GetOperator(parameter.BaseExpression.NodeType) + " "); } else { this.Context.Result.Append(result); } parameter.CommonTempData = null; } private void ResolveLength(ExpressionParameter parameter, bool? isLeft, MemberExpression expression) { var ps=ExpressionTool.GetParameters(expression); if (expression.Expression!=null&&ps.Count == 0) { var p = base.AppendParameter(ExpressionTool.DynamicInvoke(expression.Expression)); var methodParamter2 = new MethodCallExpressionArgs() { IsMember =true, MemberName =p, MemberValue = null }; var result2 = this.Context.DbMehtods.Length(new MethodCallExpressionModel() { Args = new List() { methodParamter2 } }); base.AppendMember(parameter, isLeft, result2); return; } if (parameter.Context.ResolveType == ResolveExpressType.FieldSingle) { parameter.Context.ResolveType = ResolveExpressType.WhereSingle; } if (parameter.Context.ResolveType == ResolveExpressType.FieldMultiple) { parameter.Context.ResolveType = ResolveExpressType.WhereMultiple; } var oldCommonTempDate = parameter.CommonTempData; parameter.CommonTempData = CommonTempDataType.Result; this.Expression = expression.Expression; var isConst = this.Expression is ConstantExpression; this.Start(); var methodParamter = new MethodCallExpressionArgs() { IsMember = !isConst, MemberName = parameter.CommonTempData, MemberValue = null }; var result = this.Context.DbMehtods.Length(new MethodCallExpressionModel() { Args = new List() { methodParamter } }); base.AppendMember(parameter, isLeft, result); parameter.CommonTempData = oldCommonTempDate; } #endregion #region Helper private static bool IsConvertMemberName(MemberExpression expression) { return expression.Expression is UnaryExpression && (expression.Expression as UnaryExpression).Operand is ParameterExpression; } private static bool IsDateDiff(MemberExpression expression) { if (expression.Expression != null && expression.Expression is BinaryExpression) { var binExp = (expression.Expression as BinaryExpression); var nodeType= binExp.NodeType; if (nodeType == ExpressionType.Subtract&& binExp.Left.Type==UtilConstants.DateType && binExp.Right.Type == UtilConstants.DateType) { return true; } } return expression.Expression!=null&& expression.Expression is BinaryExpression && expression.Expression.Type == UtilConstants.TimeSpanType&& expression.Member.Name.StartsWith("Total")&& expression.Member.Name.EndsWith("s") ; } private string AppendMember(ExpressionParameter parameter, bool? isLeft, string fieldName) { if (parameter.BaseExpression is BinaryExpression || (parameter.BaseParameter.CommonTempData != null && parameter.BaseParameter.CommonTempData.Equals(CommonTempDataType.Append))) { fieldName = string.Format(" {0} ", fieldName); if (isLeft == true) { fieldName += ExpressionConst.ExpressionReplace + parameter.BaseParameter.Index; } if (base.Context.Result.Contains(ExpressionConst.FormatSymbol)) { base.Context.Result.Replace(ExpressionConst.FormatSymbol, fieldName); } else { base.Context.Result.Append(fieldName); } } else { base.Context.Result.Append(fieldName); } return fieldName; } private string GetName(ExpressionParameter parameter, MemberExpression expression, bool? isLeft, bool isSingle) { if (isSingle) { return GetSingleName(parameter, expression, IsLeft); } else { return GetMultipleName(parameter, expression, IsLeft); } } private string GetMultipleName(ExpressionParameter parameter, MemberExpression expression, bool? isLeft) { string shortName = expression.Expression.ToString(); string fieldName = expression.Member.Name; fieldName = this.Context.GetDbColumnName(expression.Expression.Type.Name, fieldName); if (UtilMethods.GetMoreSetting(this.Context).IsCorrectErrorSqlParameterName) { fieldName = Context.GetTranslationColumnName(shortName) + UtilConstants.Dot + Context.GetTranslationColumnName(fieldName); } else { fieldName = Context.GetTranslationColumnName(shortName + UtilConstants.Dot + fieldName); } return fieldName; } private string GetSingleName(ExpressionParameter parameter, MemberExpression expression, bool? isLeft) { string fieldName = expression.Member.Name; fieldName = this.Context.GetDbColumnName(expression.Expression.Type.Name, fieldName); var isSpace = fieldName.Contains(UtilConstants.Space); var guid = string.Empty; if (isSpace) { guid = SnowFlakeSingle.Instance.NextId().ToString(); fieldName = fieldName.Replace(UtilConstants.Space, guid); } fieldName = Context.GetTranslationColumnName(fieldName); if (this.Context?.SugarContext?.Context?.CurrentConnectionConfig?.MoreSettings?.IsCorrectErrorSqlParameterName == true&& fieldName?.Contains(ExpressionConst.LeftParenthesis)==true) { fieldName = Context.GetTranslationText(fieldName); } if (isSpace) { fieldName = fieldName.Replace(guid, UtilConstants.Space); } return fieldName; } private string GetDateValue(object value, DateType type) { var pars = new MethodCallExpressionModel() { Conext=this.Context, Args = new List() { new MethodCallExpressionArgs() { IsMember=true, MemberName=value, MemberValue=value }, new MethodCallExpressionArgs() { MemberName=type, MemberValue=type} } }; return this.Context.DbMehtods.DateValue(pars); } private string GetToDateShort(string value) { var pars = new MethodCallExpressionModel() { Args = new List() { new MethodCallExpressionArgs() { MemberName=value, MemberValue=value }, } }; return this.Context.DbMehtods.ToDateShort(pars); } private void SettingParameters(ExpressionParameter parameter, out ExpressionParameter baseParameter, out MemberExpression expression, out bool? isLeft, out bool isSetTempData, out bool isValue, out bool isValueBool, out bool isLength, out bool isDateValue, out bool isHasValue, out bool isDateDate, out bool isMemberValue, out bool isSingle, out bool fieldIsBool, out bool isSelectField, out bool isField) { baseParameter = parameter.BaseParameter; expression = base.Expression as MemberExpression; var childExpression = expression.Expression as MemberExpression; var memberName = expression.Member.Name; var childIsMember = childExpression != null; var isRoot = parameter.BaseExpression == null; isLeft = parameter.IsLeft; isSetTempData = parameter.IsSetTempData; isValue = memberName == "Value" && expression.Member.DeclaringType.Name == "Nullable`1"; var isBool = expression.Type == UtilConstants.BoolType; isValueBool = isValue && isBool && isRoot; isLength = memberName == "Length" && childIsMember && childExpression.Type == UtilConstants.StringType; isDateValue = memberName.IsIn(Enum.GetNames(typeof(DateType))) && (childIsMember && childExpression.Type == UtilConstants.DateType); if (isDateValue == false && childIsMember && childExpression?.Type?.FullName == "System.DateOnly"&& memberName.IsIn(Enum.GetNames(typeof(DateType)))) { isDateValue = true; } var isLogicOperator = ExpressionTool.IsLogicOperator(baseParameter.OperatorValue) || baseParameter.OperatorValue.IsNullOrEmpty(); isHasValue = isLogicOperator && memberName == "HasValue" && expression.Expression != null && expression.NodeType == ExpressionType.MemberAccess; isDateDate = memberName == "Date" && expression.Expression.Type == UtilConstants.DateType; isMemberValue = expression.Expression != null && expression.Expression.NodeType != ExpressionType.Parameter && !isValueBool; isSingle = parameter.Context.ResolveType.IsIn(ResolveExpressType.WhereSingle, ResolveExpressType.SelectSingle, ResolveExpressType.FieldSingle, ResolveExpressType.ArraySingle); fieldIsBool = isBool && isLogicOperator && (parameter.BaseParameter == null || !(parameter.BaseParameter.CurrentExpression is MemberInitExpression || parameter.BaseParameter.CurrentExpression is NewExpression)); var isSelect = this.Context.ResolveType.IsIn(ResolveExpressType.SelectSingle, ResolveExpressType.SelectMultiple); isSelectField = isSelect && isRoot; isField = this.Context.ResolveType.IsIn(ResolveExpressType.FieldSingle, ResolveExpressType.FieldMultiple); } #endregion } }