Could you hire me? Contact me if you like what I’ve done in this article and think I can create value for your company with my skills.

December 8, 2009 / by Zsolt Soczó

Szűrés opcionális paraméterekre LINQ-val

A feladvány, hogy van sok szűrési feltétel, ezekre szűrni kell, ha van érvényes értékük, vagy kihagyni a szűrésből, ha nincs.
A feladatra SQL Server esetén bool algebrás megoldást írnék:

select * from tabla
where 
(@p1 is null) or (@p1 = col1)
and
(@p2 is null) or (@p2 = col2)
...
option(recompile)

Az option hint azért kell, mert így a nullos paraméterek teljesen kiesnek a tervből, csak a valódi szűrésekre készül terv. Ez szerintem óriási dolog, érdemes észben tartani.

Ugyanezt a logikát linqval is el lehet játszani, ref típusokkal kb. így:

var x = from z in Valami
where (p1 == null) || (p1 = z.col1)
&&
(p2 == null) || (p2 = z.col2)

Egy másik megoldásban azt használjuk ki, hogy késleltetett módon értékelődnek ki a kifejezések, így lehet őket láncolni. Itt látható ez a megoldás, és még más megközelítések is.

A harmadik megoldásban írhatunk egy saját szűrő operátort is erre a célra. Az előbbi címről:

public static IQueryable WhereIf(
this IQueryable source, bool condition,
Expression> predicate)
{
if (condition)
return source.Where(predicate);
else
return source;
}

Nehéz megindokolni, melyik megoldás a jobb.

Could you hire me? Contact me if you like what I’ve done in this article and think I can create value for your company with my skills.

LEAVE A COMMENT

1 COMMENTS

  • Zetor January 14, 2010

    Én a másodikat szeretem, mert olvasható lesz a kód tőle. Nagyon gatyán néz ki, ha mondjuk van 10-15 szűrőfeltétel és azt belemasszírozzuk egy nagy linq where-be…

    -Z