![]() |
Datenbank: firebird • Zugriff über: ibx, ibexpert
indizes generieren?
hallo
angenommen ich habe eine firebird-datenbank per skript erstellt in dem für bestimmte felder indizes geschaffen worden sind: wenn ich jetzt nach und nach einträge in die datenbank einfüge, werden dann die indizes immer automatisch (re)generiert oder muss ich das irgendwie veranlassen? habe mir nämlich grade mal testweise eine "zufalls"-datenbank erstellen lassen mit mehr als 100000 einträgen und irgendwie hatte ich mir das auffinden von einträgen über indizes schneller vorgestellt... danke, martin |
Re: indizes generieren?
Zitat:
Zitat:
|
Re: indizes generieren?
Liste der Anhänge anzeigen (Anzahl: 1)
SQL-Code:
Ich hatte auch schon überlegt, ob es vielleicht an den Queries liegen könnte, und dass diese vielleicht zu umständlich formuliert sind, aber dann dachte ich mir, die Queries werden doch nachher von Firebird sowieso optimiert, oder?
DB-Struktur? Messwerte? Genaue Abfragen?
Das Skript zur Erstellung der Datenbank hab ich hochgeladen. Die Tabelle dicentries hat in meinem Fall so etwa 130 000 Einträge. Um jetzt aus meiner Delphi-Anwendung (mittels der IBDataSet-Komponenten) einen Query wie
SQL-Code:
auszuführen braucht es schon so 8 Sekunden bis ich die Daten in meine Anwendung geladen bekomme..
select distinct * from dicentries where (id > 20) and (asverw is null) and (zsverw is null) order by id rows 20
Ich mach hier alles so ein bisschen 'learning by doing' also wenn euch irgendwelche Optimisierungvorschläge einfallen wär ich sehr dankbar! Martin |
Re: indizes generieren?
habe grad gemerkt, dass wenn ich 'distinct' rauslasse, gehts erheblich schneller
scheint so, als sollte man das auch wirklich nur da wo notwendig verwenden... |
Re: indizes generieren?
Standardmäßig werden nur für Primär- und Fremdschlüsselfelder ein Index erstellt. Je nach häufigkeit der Abfrage kannst du spezielle Indizes anlegen, in welchen alle Felder die in der WHERE-Clause einer Abfrage vorkommen enthalten sind. Aber bedenke zu viele Indizes pro Tabelle sind auch schelcht, da sie INSERTs "verteuer" da bei jeder Einfügevorgang alle Indizes aktualisiert werden müssen.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 19:22 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz