EF动态linq的两种方式

mac2022-06-30  84

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

 

这个链接的动态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); // } }

 

转载于:https://www.cnblogs.com/Myability/p/9321860.html

相关资源:JAVA上百实例源码以及开源项目
最新回复(0)