AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

indizes generieren?

Ein Thema von sancho1980 · begonnen am 12. Mai 2006 · letzter Beitrag vom 12. Mai 2006
Antwort Antwort
sancho1980

Registriert seit: 7. Feb 2006
429 Beiträge
 
#1

indizes generieren?

  Alt 12. Mai 2006, 15:38
Datenbank: firebird • Zugriff über: ibx, ibexpert
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
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: indizes generieren?

  Alt 12. Mai 2006, 15:47
Zitat von sancho1980:
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?
Jede vernünftigen Datenbank macht das automatisch. Viele Datenbanken bieten zur weiteren Performancesteigerung per Batch startbare Reorganisationsläufe

Zitat von sancho1980:
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...
DB-Struktur? Messwerte? Genaue Abfragen?
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
sancho1980

Registriert seit: 7. Feb 2006
429 Beiträge
 
#3

Re: indizes generieren?

  Alt 12. Mai 2006, 15:59
DB-Struktur? Messwerte? Genaue Abfragen? 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?

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

select distinct * from dicentries where (id > 20) and (asverw is null) and (zsverw is null) order by id rows 20 auszuführen braucht es schon so 8 Sekunden bis ich die Daten in meine Anwendung geladen bekomme..

Ich mach hier alles so ein bisschen 'learning by doing' also wenn euch irgendwelche Optimisierungvorschläge einfallen wär ich sehr dankbar!

Martin
Angehängte Dateien
Dateityp: rar huge_167.rar (2,3 KB, 5x aufgerufen)
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
sancho1980

Registriert seit: 7. Feb 2006
429 Beiträge
 
#4

Re: indizes generieren?

  Alt 12. Mai 2006, 16:05
habe grad gemerkt, dass wenn ich 'distinct' rauslasse, gehts erheblich schneller
scheint so, als sollte man das auch wirklich nur da wo notwendig verwenden...
Um Rekursion zu verstehen, muss man zunächst Rekursion verstehen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: indizes generieren?

  Alt 12. Mai 2006, 16:24
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.
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:30 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz