Expression.Lambda и генерация запроса во время выполнения, простейший пример «Где»

Я безуспешно пытался сгенерировать простое лямбда-выражение во время выполнения ... что-то вроде этого:

var result = queryableData.Where(item => item.Name == "Soap")

Вот мой пример класса и прибор, который можно запросить:

public class Item
{
    public int Id { get; set; }
    public string Name { get; set; }
}

IQueryable<Item> queryableData = ...;

Затем я генерирую лямбда-выражение во время выполнения , правильный код следует :

//"item" in "item =>..."
var item = Expression
    .Parameter(typeof(Item), "item");

//property of my item, this is "item.Name"
var prop = Expression
    .Property(item, "Name");

//then "Soap" in '... => item.Name=="Soap"'
var value = Expression.Constant("Soap");

//equality expression "==" in my primer
var equals = Expression.Equal(prop, value);

//then lambda
var lambda = Expression.Lambda<Func<Item, bool>>(equals, item);

//and here are the results    
var results = queryableData.Where(lambda);

Большое спасибо dtb за совет!

43
задан CodeAddicted 29 November 2011 в 18:57
поделиться