Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 438|回复: 0

C# Expression 树转化为SQL与语句(二)--解决参数问题

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-5-20 05:19:24 | 显示全部楼层 |阅读模式

      在用Expression解析的的时候碰到一些参数(不是具体的值),会出现这种情况。

      

      在这里我们希望得到的是id=10,而不是id=m_id;那如何来解析这些参数?

    ====================================================================================================\

      首先参数分为2中,一种是n.id,这种可以说是一种形参,没有具体的数据只是泛型中的一个属性,这种应该被解析成字符串id,另外一种是m_id,这种是有具体的值得,我们希望它解析成具体的值(10)而不是m_id。在Expression的子类中的MemberExpression类接收。我们来看看MemberExpression的信息

      

      我们可以通过MemberExpression类的Expression 来确定参数的类型,判断这个参数是那种类型。

      

    1  public class StudentHelper
    2     {
    3         public int id1  { get; set; }                   //属性
    4         public int id2;                                 //字段
    5         public static int id3 { get { return 10; } }    //静态属性
    6         public static int id4 = 20;                     //静态字段
    7      
    8     }
    一个数据类

     

     1   public static void Main(string[] args)
     2         {
     3             StudentHelper h = new StudentHelper();
     4             h.id1 = 1;
     5             h.id2 = 2;
     6             Expression<Func<Student, bool>> la1 = n=> n.id == h.id1;
     7             Expression<Func<Student, bool>> la2 = n=> n.id == h.id2;
     8             Expression<Func<Student, bool>> la3 = n=> n.id == StudentHelper.id3;
     9             Expression<Func<Student, bool>> la4 = n=> n.id == StudentHelper.id4;
    10             Expression<Func<Student, bool>> la5 = n=> n.id == n.new_id;
    11             test(la1,"属性");
    12             test(la2, "字段");
    13             test(la3, "静态属性");
    14             test(la4, "静态字段");
    15             test(la5, "自身参数");
    16             Console.ReadLine();
    17         }
    18         public static void test(Expression<Func<Student, bool>> la,string name)
    19         {
    20             Console.WriteLine("\n\n*****************"+name+"*********************");
    21             BinaryExpression B_exp = la.Body as BinaryExpression;
    22             Console.WriteLine("Expression类名:"+B_exp.Right.GetType().Name);
    23             MemberExpression m_exp = B_exp.Right as MemberExpression;
    24             string valueClassName = string.Empty;
    25             if (m_exp.Expression == null)
    26             {
    27                 Console.WriteLine("数据为空");
    28             }
    29             else
    30             {
    31                 valueClassName = m_exp.Expression.GetType().Name;
    32                 Console.WriteLine("数据Expression类名:" + valueClassName);
    33             }
    34             Console.WriteLine("\n\n*********************************************");
    35         }

    调试结果:

    通过调试结果可以看到自身的参数其数据对象为类型TypedParameterExpression,不是有2中可能静态的字段和属性其数据对象为空,有则为FieldExpression类型。判断完后就可以把表达式当成委托编译出来。

    具体代码如下:

    1 public static object Eval(MemberExpression member)
    2         {
    3             UnaryExpression cast = Expression.Convert(member, typeof(object));
    4             object obj = Expression.Lambda<Func<object>>(cast).Compile().Invoke();
    5             return obj;
    6         }

    最后把代码嵌入进入:

    调试结果为

      

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-4 10:31 , Processed in 0.094696 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表