Einzelnen Beitrag anzeigen

idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#11

AW: Tabellenübergreifender Index

  Alt 20. Jun 2010, 10:20
Insgesant sind in der Tabelle ca 120000 Datensätze, die folgenden Queries liefern davon ca 55000
SQL-Code:
select * from musik
where (titel like '% %') and (Titel>'lo')
order by titel
SQL-Code:
select * from musik
where (titel like '% %') and (Titel>'lo')
order by titel,ip_name
ip_name ist jetzt ein berechnetes feld in der tabelle Musik, das ist immer noch um einiges schneller als ein joint der beiden Tabellen.

Die erste Abfrage liefert die ersten 20 Datensätze innerhalb von weniger als 1 Sekunde, ein Sprung ans Ende des Ergebnis-Sets dauert ca 4 Sekunden.
Die zweite Abfrage liefert die ersten 20 Datensätze innerhalb ca 35 Sekunden, ein Sprung ans Ende des Ergebnis-Sets dauert noch einmal ca 35 Sekunden.

Der einzige Unterschied ist die zusätzliche Sortierung nach dem Feld IP_Name, das ich, weil es ein berechneter Wert ist, nicht in den Index einbeziehen kann.

Natürlich kann ich zur Not eine Shadow-Spalte in der Tabelle Musik einrichten und über Trigger füllen, aber das kann es ja wohl nicht sein?

Geändert von mkinzler (20. Jun 2010 um 12:15 Uhr) Grund: Code-Tag duch SQL-Tag ersetzt
  Mit Zitat antworten Zitat