Glorf.it

Glorf IT

Bedenkliches aus dem IT-Alltag

19. Juni 2007 um 19:57

Seadragon: Fotos verlinken und verbinden

Bis gerade eben hatte ich noch keine Ahnung, was "Seadragon" ist, aber nachdem ich dieses wirklich interessante Video bei TED sah, bin ich schwer beeindruckt. Auf diese Weise werden wir in ein paar Jahren alle Bilder bei Flickr &Co vernetzen und einfach unglaubliche Dinge damit erreichen. Wenn man das jetzt noch mit Google-Earth verbindet, dann kann man im Prinzip jeden Bildband vergessen!

Hier steht mehr zu der Software: http://labs.live.com/Seadragon.aspx

gefunden im WiMaBlog
19. Juni 2007 um 19:23

SQL-Server: Paging von Ergebnismengen

Heute wollte ich einen Trick vorstellen, wie man es schafft eine Ergebnismenge seitenweise zu lesen. Das ist sinnvoll, wenn man in der Anwendung immer nur eine "Seite" voller Datensätze anzeigt. Es wäre in dem Fall Quatsch Tausende von Sätzen zu lesen und am Client dann doch nur eine oder zwei Seiten anzuzeigen.

Leider wird das derzeit schlaueste Verfahren im Artikel "Server Side Paging using SQL Server 2005" auf SQLTeam.com so schön beschrieben, dass ich mir meine Version an dieser Stelle schenke. Allerdings möchte ich ein paar persönliche Bemerkungen ergänzen:

  • Ich würde generell zu einem Index auf dem Sortierkriterium raten, am besten sollte man auf dem Clustered-Index "pagen". Für meinen untigen Trick ist das ein Muss.
  • Es ist wichtig, dass man die Menge der Datensätze mittels der Where-Klause auf die wirklich benötigten Sätze einschränkt, sonst beschäftigt man den SQL-Server unnötig. Aber ich gehe davon aus, dass Ihr das schon macht.
  • Wenn man sehr, sehr viele Datensätze im Ergebnis hat über das man "pagen" will, dann würde ich dazu raten, die Query so abzuspecken, dass nur der Primärschlüssel in der Common-Table-Expression ist. Dann kann die "Zählung" auf dem Sortierkriterium (und der Where-Klausel) mittels "Index Covering" durchgeführt werden. Das Ergebnis wird dann wieder mit der originalen Tabelle verjoint.

Frohes "pagen"…

|