zoukankan      html  css  js  c++  java
  • 学习笔记: Expression表达式目录树详解和扩展封装

    1. 表达式链接扩展封装,ORM常用 And  Or

    /// <summary>
    /// 表达式访问者
    /// </summary>
    public class ExpressionVisitorTest
    {

        public static void Show()
         {
            

            #region 表达式链接
             {
                 Expression<Func<People, bool>> lambda1 = x => x.Age > 5;
                 Expression<Func<People, bool>> lambda2 = x => x.Id > 5;
                 Expression<Func<People, bool>> lambda3 = lambda1.And(lambda2);
                 Expression<Func<People, bool>> lambda4 = lambda1.Or(lambda2);
                 Expression<Func<People, bool>> lambda5 = lambda1.Not();
                 Do1(lambda3);
                 Do1(lambda4);
                 Do1(lambda5);
             }
             #endregion


         }
         #region PrivateMethod
         private static void Do1(Func<People, bool> func)
         {
             List<People> people = new List<People>();
             people.Where(func);
         }
         private static void Do1(Expression<Func<People, bool>> func)
         {
             List<People> people = new List<People>()
             {
                 new People(){Id=4,Name="123",Age=4},
                 new People(){Id=5,Name="234",Age=5},
                 new People(){Id=6,Name="345",Age=6},
             };

            List<People> peopleList = people.Where(func.Compile()).ToList();
         }

        private static IQueryable<People> GetQueryable(Expression<Func<People, bool>> func)
         {
             List<People> people = new List<People>()
             {
                 new People(){Id=4,Name="123",Age=4},
                 new People(){Id=5,Name="234",Age=5},
                 new People(){Id=6,Name="345",Age=6},
             };

            return people.AsQueryable<People>().Where(func);
         }
         #endregion
    }

  • 相关阅读:
    Cheap Kangaroo(求多个数的最大公约数)
    poj 1094 Sorting It All Out(拓扑排序)
    hdu 5695 Gym Class(拓扑排序)
    Cyclic Components (并查集)
    GCD LCM
    And Then There Was One (约瑟夫环变形)
    System Overload(约瑟夫环变形)
    POJ-1639 Picnic Planning 度数限制最小生成树
    Educational Codeforces Round 60 (Rated for Div. 2) E. Decypher the String
    (ACM模板)二分查找
  • 原文地址:https://www.cnblogs.com/xtxtx/p/9162432.html
Copyright © 2011-2022 走看看