Quantcast
Channel: How to convert an expression tree to a partial SQL query? - Stack Overflow
Viewing all articles
Browse latest Browse all 10

Answer by James Johnson for How to convert an expression tree to a partial SQL query?

$
0
0

Not sure if this is exactly what you need, but it looks like it might be close:

string[] companies = { "Consolidated Messenger", "Alpine Ski House", "Southridge Video", "City Power & Light","Coho Winery", "Wide World Importers", "Graphic Design Institute", "Adventure Works","Humongous Insurance", "Woodgrove Bank", "Margie's Travel", "Northwind Traders","Blue Yonder Airlines", "Trey Research", "The Phone Company","Wingtip Toys", "Lucerne Publishing", "Fourth Coffee" };// The IQueryable data to query.IQueryable<String> queryableData = companies.AsQueryable<string>();// Compose the expression tree that represents the parameter to the predicate.ParameterExpression pe = Expression.Parameter(typeof(string), "company");// ***** Where(company => (company.ToLower() == "coho winery" || company.Length > 16)) *****// Create an expression tree that represents the expression 'company.ToLower() == "coho winery"'.Expression left = Expression.Call(pe, typeof(string).GetMethod("ToLower", System.Type.EmptyTypes));Expression right = Expression.Constant("coho winery");Expression e1 = Expression.Equal(left, right);// Create an expression tree that represents the expression 'company.Length > 16'.left = Expression.Property(pe, typeof(string).GetProperty("Length"));right = Expression.Constant(16, typeof(int));Expression e2 = Expression.GreaterThan(left, right);// Combine the expression trees to create an expression tree that represents the// expression '(company.ToLower() == "coho winery" || company.Length > 16)'.Expression predicateBody = Expression.OrElse(e1, e2);// Create an expression tree that represents the expression// 'queryableData.Where(company => (company.ToLower() == "coho winery" || company.Length > 16))'MethodCallExpression whereCallExpression = Expression.Call(    typeof(Queryable),"Where",    new Type[] { queryableData.ElementType },    queryableData.Expression,    Expression.Lambda<Func<string, bool>>(predicateBody, new ParameterExpression[] { pe }));// ***** End Where *****// ***** OrderBy(company => company) *****// Create an expression tree that represents the expression// 'whereCallExpression.OrderBy(company => company)'MethodCallExpression orderByCallExpression = Expression.Call(    typeof(Queryable),"OrderBy",    new Type[] { queryableData.ElementType, queryableData.ElementType },    whereCallExpression,    Expression.Lambda<Func<string, string>>(pe, new ParameterExpression[] { pe }));// ***** End OrderBy *****// Create an executable query from the expression tree.IQueryable<string> results = queryableData.Provider.CreateQuery<string>(orderByCallExpression);// Enumerate the results.foreach (string company in results)    Console.WriteLine(company);

Viewing all articles
Browse latest Browse all 10

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>