Dynamic Query with Multiple Conditions
This example dynamically creates a query with AND or OR conditions based on user input.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
class Program
{
static void Main()
{
var people = new List<Person>
{
new Person { Name = "Alice", Age = 25 },
new Person { Name = "Bob", Age = 30 },
new Person { Name = "Charlie", Age = 35 }
};
var parameter = Expression.Parameter(typeof(Person), "x");
// Dynamic conditions
var ageProperty = Expression.Property(parameter, "Age");
var constant1 = Expression.Constant(30);
var greaterThan = Expression.GreaterThan(ageProperty, constant1);
var nameProperty = Expression.Property(parameter, "Name");
var constant2 = Expression.Constant("Charlie");
var equal = Expression.Equal(nameProperty, constant2);
// Combine with OR: (x.Age > 30) || (x.Name == "Charlie")
var orExpression = Expression.OrElse(greaterThan, equal);
var lambda = Expression.Lambda<Func<Person, bool>>(orExpression, parameter);
var result = people.AsQueryable().Where(lambda).ToList();
foreach (var person in result)
{
Console.WriteLine($"{person.Name}, {person.Age}");
}
}
}