lunedì 27 luglio 2009

VB.NET : Un metodo di estensione per recuperare, tramite LINQ, un record casuale da una collezione.

Vi segnalo su DotNetRomaCestà un mio tip riguardante LINQ ed esattamente la possibilità di recuperare casualmente un record all’interno di una collezione di elementi.

Riporto interamente il tip per semplicità ma potete trovarlo anche al link.

Questo piccolo trucco può sembrare inutile (e forse lo è), ma può avere utilità quando si ha la necessità di visualizzare, casualmente, un elemento preso da una collezione (ad esempio vetrine, banner pubblicitari, etc., etc.).

Si tratta di un metodo di estensione che si applica ad un’istanza di IQueryable(Of T) e restituisce un oggetto di classe T recuperato a caso (utilizzando il generatore di numeri casuale fornito dalla classe Random del Framework):

<Extension()> _
Public Function GetRandom(Of T) _
    (ByVal coll As IQueryable(Of T)) As T
  Dim retval As T
  Dim rnd As New Random(DateTime.Now.Millisecond)
  retval = coll.Skip(Convert.ToInt32(rnd.NextDouble* _
    (coll.Count - 1))).Take(1).FirstOrDefault
  Return retval
End Function

Il metodo, purtroppo, esegue due query sulla collezione (una per il count e l’altra per il recupero del record) e questo, comporta, in caso di collezioni provenienti da database (ad esempio LINQ to SQL), ad un doppio accesso alla banca dati.

Nessun commento: