EF动态linq的两种方式

网上收集的资源  我怕遗忘就在自己博客记录下,有些我忘记原文地址了请见谅

 

这个链接的动态sql方式是 where("c=>c.id==id")

https://weblogs.asp.net/scottgu/dynamic-linq-part-1-using-the-linq-dynamic-query-library

还有一种方式  必须需要实体类的  但是需要注意的是  需要LinqKit.dll并且在  where条件前加上.AsExpandable(). 

public static class EFHelper
    {

        ///// <summary>
        ///// 一個老外寫的擴充Expression方法的靜態類別,可以解決上面冗長的程式碼
        ///// </summary>
        //public static class DynamicLinqExpressions//注意static靜態型別
        //{
        public static Expression<Func<T, bool>> True<T>() { return f => true; }
        public static Expression<Func<T, bool>> False<T>() { return f => false; }

        //注意this
        public static Expression<Func<T, bool>> Or<T>(this Expression<Func<T, bool>> expr1,
                                                            Expression<Func<T, bool>> expr2)
        {
            var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
            return Expression.Lambda<Func<T, bool>>
                  (Expression.Or(expr1.Body, invokedExpr), expr1.Parameters);
        }

        public static Expression<Func<T, bool>> AndContation<T>(this Expression<Func<T, bool>> expr1,
                                                             Expression<Func<T, bool>> expr2)
        {
            var invokedExpr = Expression.Invoke(expr2, expr1.Parameters.Cast<Expression>());
            return Expression.Lambda<Func<T, bool>>
                  (Expression.And(expr1.Body, invokedExpr), expr1.Parameters);
        }


        //        使用示例:


                   SchoolContainer school = new SchoolContainer();
                   var eps = DynamicLinqExpressions.True<Teacher>();
        //            eps.And(T=>T.Name.Contains("1"));
        //            var ss = school.Teacher.Where(T => T.Name.Contains("PM")).Where(eps);
        //            foreach (var item in ss)
        //            {
        //                Console.WriteLine(item.Name);
        //            }


    }

 

posted @ 2018-07-17 10:09  ...willing  阅读(269)  评论(0编辑  收藏  举报