Expression 生成 Lambda

public static event Func<Student, bool> myevent;
        public delegate void del(int i, int j);
        static void Main(string[] args)
        {
            
            var students = new List<Student> { 
              new Student(){ Id=3, Age=20, Name="张三1", Sex=true   , GradeId=1},
              new Student(){ Id=1, Age=22, Name="李四1", Sex= false , GradeId=2},
              new Student(){ Id=4, Age=13, Name="王二", Sex= false , GradeId=1},
              new Student(){ Id=2, Age=11, Name="赵六", Sex=true   , GradeId=2},
            
            };

            // BookShopPlus2Entities db = new BookShopPlus2Entities();
            //AsNoTracking查询的对象不要放在对象池中
            //特别说明:对于使用AsNoTracking()的数据不能用于修改。
            //List<Book> db = bsc.Books.AsNoTracking().ToList();

            //del mydel = new del(add);
            //mydel.Invoke(1, 9);
            //// //匿名方法
            //mydel += delegate(int h, int m)
            //{

            //};
            ////Lamda表达式
            //mydel += (a, b) =>
            //{
            //    Console.WriteLine(a + b);
            //};

            //生成 1==1
            Expression expwhere = Expression.Equal(Expression.Constant(1), Expression.Constant(1));
            //生成 s=>
            ParameterExpression exps = Expression.Parameter(typeof(Student), "s");
            //生成s.Age>12
            Expression exp1 = Expression.GreaterThan(Expression.Property(exps, "Age"), Expression.Constant(12));
            //生成s.Age<22
            Expression exp2 = Expression.LessThan(Expression.Property(exps, "Age"), Expression.Constant(22));
            //生成 s.Age>12 and  s.Age<22  或连接 Expression.Or  and 连接   Expression.And
            Expression exp3 = Expression.And(exp1, exp2);     
            //Expression<Func<Student, bool>> lamband = Expression.Lambda < Func<Student, bool>.Combine();
            //生成s=>Age>12 AND    s.Age<22
            Expression<Func<Student, bool>> lamband =
            Expression.Lambda<Func<Student, bool>>(exp3, exps);
            var s = students.Where(lamband.Compile()).ToList();
        }

        
    }
    public class Student
    {
        public int Id { get; set; } //学号
        public string Name { get; set; } //学员姓名
        public int Age { get; set; } //学生年龄
        public bool Sex { get; set; } //学生性别
        public int GradeId { get; set; }
    }

 

转载于:https://www.cnblogs.com/wlzhang/p/7690630.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值