zoukankan      html  css  js  c++  java
  • 动态拼接Lambda表达式-表达式目录树动态构建及修改-----表达式树的访问过程,并转化成sql语句

    代码如下:

     #region 表达式树的访问过程,并转化成sql语句
            /// <summary>
            /// 访问 表达式树 Expression<Func<MyClass, bool>> expressionFunc = x => x.Age > 5 &&  x.Id == 8;
            /// 并转化成sql语句 select * from MyClass where age > 5 and id = 8
            /// </summary>
            public class OperatorExpressionToSql : ExpressionVisitor
            {
                /// <summary>
                /// 存放Expression表达式树的内容
                /// </summary>
                public Stack<string> StackSet { get; set; }
    
    
                public OperatorExpressionToSql()
                {
                    StackSet = new Stack<string>();
                    StackSet.Push("(");
                }
                /// <summary>
                /// 修改表达式树的形式
                /// </summary>
                /// <param name="expression"></param>
                /// <returns></returns>
                public Expression Modify(Expression expression)
                {
                    //base.Visit(expression);
                    //if (expression is BinaryExpression binary)
                    //{
                    //    if (binary.NodeType == ExpressionType.Add)
                    //    {
                    //        var left = base.Visit(binary.Left); ;
                    //        var right = base.Visit(binary.Right);
                    //        var result = Expression.Subtract(left, right);
                    //        return result;
                    //    }
                    //}
                    return base.Visit(expression);
                }
    
                /// <summary>
                /// 表达式树的二元操作
                /// </summary>
                /// <param name="node"></param>
                /// <returns></returns>
                protected override Expression VisitBinary(BinaryExpression node)
                {
                    if (node.NodeType == ExpressionType.AndAlso)
                    {
                        base.Visit(node.Left);
                        StackSet.Push("and");
                        base.Visit(node.Right);
                        //var result = Expression.Subtract(left, right);
                        //return result;
                        StackSet.Push(")");
                    }
                    else if (node.NodeType == ExpressionType.GreaterThan)
                    {
                        if (node.Left is MemberExpression member)
                        {
                            StackSet.Push(member.Member.Name);
                        }
                        StackSet.Push(">");
                        if (node.Right is ConstantExpression constant)
                        {
                            StackSet.Push(constant.Value.ToString());
                        }
                    }
                    else if (node.NodeType == ExpressionType.Equal)
                    {
                        if (node.Left is MemberExpression member)
                        {
                            StackSet.Push(member.Member.Name);
                        }
                        StackSet.Push("=");
                        if (node.Right is ConstantExpression constant)
                        {
                            StackSet.Push(constant.Value.ToString());
                        }
                    }
    
                    //StackSet.Push(node.Value.ToString());
                    return node;
                    //return base.VisitBinary(node);
                }
    
                /// <summary>
                /// 表达式树的常量操作
                /// </summary>
                /// <param name="node"></param>
                /// <returns></returns>
                protected override Expression VisitConstant(ConstantExpression node)
                {
                    StackSet.Push(node.Value.ToString());
                    return base.VisitConstant(node);
                }
            }
    
            /// <summary>
            /// 测试表达式树的访问过程,并转化成sql语句
            /// </summary>
            public static void TestDynamicExpressionToSql()
            {
                //访问 表达式树 
                Expression<Func<MyClass, bool>> expressionFunc = x => x.Age > 5 && x.Name == "8";
                /// 并转化成sql语句 select * from MyClass where age > 5 and id = 8
                OperatorExpressionToSql visitor = new OperatorExpressionToSql();
                var expression = visitor.Modify(expressionFunc.Body);
                var d = string.Join(' ', visitor.StackSet.Reverse().ToArray());
                //while (visitor.StackSet.Count > 0)
                //{
                //    Console.WriteLine($"结果:{visitor.StackSet.Pop()}");
                //}
                Console.WriteLine($"结果:{d}");
            }
            #endregion
  • 相关阅读:
    处理了一个“服务器能ping得通,但telnet连接失败”导致数据库登录不了的问题
    解决了一个oracle登录缓慢的问题
    今天解决了一个mysql远程登录和本机ip登录都失败的问题
    c++笔记
    c语言笔记
    常见并发与系统设计
    linux网络IO笔记
    linux文件IO全景解析
    linux网络协议笔记
    长大后才懂的蜡笔小新 ​​​​
  • 原文地址:https://www.cnblogs.com/1175429393wljblog/p/14075138.html
Copyright © 2011-2022 走看看