I’m trying to get the following SQL query to work in LINQ:
Select id from table1 where id in (1,2) or canceledId in (1,2)
I’m using BuildContainsExpression to achieve the “IN” condition, but I can’t figure out how to implement the “or” condition.
My shot in the dark is as follows:
var identifiers = new List<int> {1,2};
var query = (from t in Context.Table1
select t);
var query =
query.Where(BuildContainsExpression<Table1, int>(t => t.Id, identifiers));
if (showCanceled)
{
var expression = query.Where(BuildContainsExpression<Table1, int>(t => t.CanceledId.Value, identifiers)).Expression;
Expression.Or(expression, transactionsQuery.Expression);
}
But I get the following exception:
The binary operator Or is not defined for the types ‘System.Linq.IQueryable1[Table1]' and 'System.Linq.IQueryable1[Table1]’..
Any ideas? -Am I in the right direction?
Thanks,
Nir.
You are appending your OR in the wrong place. What you are doing now is effectively something like this:
The second problem is that the
BuildContainsExpressionmethod you use, returns a lambda expression, something that looks like this:You can’t change this expression once it’s generated. However, that’s what you want because you’d like to have something like this:
You can’t simply take the body of this lambda expression and or it together with another expression because it depends on the parameter
t.So what you can do is the following:
Your if statement would now look like this: