网上收集的资源 我怕遗忘就在自己博客记录下,有些我忘记原文地址了请见谅
这个链接的动态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); // } }