I'm trying to figure out how to use PredicateBuilder to determine if a specific set of records exists all within an Expression. So given an OrderId and a list of ProductIds as a specification, I want to know if the Order's OrderDetail records contain all of the specification items. Not just one or some of them - but all of them.
So I could do:
var inner = PredicateBuilder.False<OrderDetail>();
foreach (int spec in specs)
{
temp = spec;
inner = inner.Or(d => d.ProductId == temp);
}
var outer = PredicateBuilder.True<OrderDetail>();
outer = outer.And(d => d.OrderId == orderId);
outer = outer.And(inner);
But then, after I get the result, I would have to a) eliminate duplicates (because in my case multiple OrderDetails can have the same ProductId) and then b) compare the result count to the spec count. All of this is doable outside the Expression, but is there an elegant way to evaluate all that in the Expression such that the result is a boolean?
That is, I'd like to have the Expression be self contained so that it can be passed around as is and those that I give it to don't have to know how to do the "post processing" to figure out if its true.