mirror of
https://github.com/nsnail/FreeSql.git
synced 2025-06-19 12:28:15 +08:00
优化 vb.net 匿名类判断
This commit is contained in:
@ -44,7 +44,7 @@ public static partial class FreeSqlGlobalExtensions
|
||||
public static bool IsIntegerType(this Type that) => that == null ? false : (_dicIsNumberType.Value.TryGetValue(that, out var tryval) ? tryval : false);
|
||||
public static bool IsNumberType(this Type that) => that == null ? false : _dicIsNumberType.Value.ContainsKey(that);
|
||||
public static bool IsNullableType(this Type that) => that.IsArray == false && that?.FullName.StartsWith("System.Nullable`1[") == true;
|
||||
public static bool IsAnonymousType(this Type that) => that?.FullName.StartsWith("<>f__AnonymousType") == true;
|
||||
public static bool IsAnonymousType(this Type that) => that == null ? false : (that.FullName.StartsWith("<>f__AnonymousType") || that.FullName.StartsWith("VB$AnonymousType"));
|
||||
public static bool IsArrayOrList(this Type that) => that == null ? false : (that.IsArray || typeof(IList).IsAssignableFrom(that));
|
||||
public static Type NullableTypeOrThis(this Type that) => that?.IsNullableType() == true ? that.GetGenericArguments().First() : that;
|
||||
internal static string NotNullAndConcat(this string that, params object[] args) => string.IsNullOrEmpty(that) ? null : string.Concat(new object[] { that }.Concat(args));
|
||||
|
@ -465,20 +465,6 @@ namespace FreeSql.Internal
|
||||
}
|
||||
public string ExpressionBinary(string oper, Expression leftExp, Expression rightExp, ExpTSC tsc)
|
||||
{
|
||||
if (leftExp.NodeType == ExpressionType.Call &&
|
||||
rightExp.NodeType == ExpressionType.Constant &&
|
||||
new[] { "=", "<>" }.Contains(oper))
|
||||
{
|
||||
var leftExpCall = leftExp as MethodCallExpression;
|
||||
//vb 语法,将字符串比较转换为了 CompareString
|
||||
if (leftExpCall.Method.Name == "CompareString" &&
|
||||
leftExpCall.Method.DeclaringType?.FullName == "Microsoft.VisualBasic.CompilerServices.Operators" &&
|
||||
leftExpCall.Arguments.Count == 3 &&
|
||||
leftExpCall.Arguments[2].Type == typeof(bool) &&
|
||||
rightExp.Type == typeof(int) &&
|
||||
(int)(rightExp as ConstantExpression).Value == 0)
|
||||
return ExpressionBinary(oper, leftExpCall.Arguments[0], leftExpCall.Arguments[1], tsc);
|
||||
}
|
||||
switch (oper)
|
||||
{
|
||||
case "OR":
|
||||
@ -498,6 +484,19 @@ namespace FreeSql.Internal
|
||||
return $"({ExpressionLambdaToSql(leftExp, tsc)} {oper} {ExpressionLambdaToSql(rightExp, tsc)})";
|
||||
case "=":
|
||||
case "<>":
|
||||
if (leftExp.NodeType == ExpressionType.Call &&
|
||||
rightExp.NodeType == ExpressionType.Constant)
|
||||
{
|
||||
var leftExpCall = leftExp as MethodCallExpression;
|
||||
//vb 语法,将字符串比较转换为了 CompareString
|
||||
if (leftExpCall.Method.Name == "CompareString" &&
|
||||
leftExpCall.Method.DeclaringType?.FullName == "Microsoft.VisualBasic.CompilerServices.Operators" &&
|
||||
leftExpCall.Arguments.Count == 3 &&
|
||||
leftExpCall.Arguments[2].Type == typeof(bool) &&
|
||||
rightExp.Type == typeof(int) &&
|
||||
(int)(rightExp as ConstantExpression).Value == 0)
|
||||
return ExpressionBinary(oper, leftExpCall.Arguments[0], leftExpCall.Arguments[1], tsc);
|
||||
}
|
||||
var exptb = _common.GetTableByEntity(leftExp.Type);
|
||||
if (exptb?.Properties.Any() == true) leftExp = Expression.MakeMemberAccess(leftExp, exptb.Properties[(exptb.Primarys.FirstOrDefault() ?? exptb.Columns.FirstOrDefault().Value)?.CsName]);
|
||||
exptb = _common.GetTableByEntity(leftExp.Type);
|
||||
|
Reference in New Issue
Block a user