Random orderby Linq és EF használatával

Az SQL Serveren szokásos orderby newid() szerveroldali megoldást csak linq to SQL esetén tudjuk kihasználni, szerveroldali függvénnyel. Az EF-ben az ilyesmi nem megy:


... orderby Guid.NewID() ...

Ez az EF verzió még nem tudja lefordítani szerveroldali kifejezéssé az orderby kifejezését.
Viszont a random rendezést át lehet nyomni kliensoldalra, ha a lekérdezést “materializáluk” (AsEnumerable) előbb:


Random rnd = new Random();
(from s in ATSEntities.Instance.Symbol
select s).AsEnumerable().OrderBy(o => rnd.Next()));

Nem guidot használtam, hanem Randomot, az kisebb költségű, és az én célomra nem baj, ha csak pszeudo-random a sorrend.

4 Responses to “Random orderby Linq és EF használatával”

  1. Meister Says:

    Viszont ez esetben a teljes recordset átmegy a kliensre?

    Azaz ha egy 1000000 rekordos táblából kéred le a top 100-at random, akkor mi megy át a kliensre?

  2. Soczó Zsolt Says:

    Persze, az egész, de úgyis kell az összes sor a kliensen. Ha nem így lenne, nem így oldanám meg.

  3. Meister Says:

    Ok, ez nem volt beleírva a post-ba. :-)

  4. Szindbad Says:

    Igazabol a newid() is pszeudo-random. :)

Leave a Reply