von Markus Winand.

Optimizer - Query Optimizer - Query Planner


Der Optimizer (Oracle), Query Optimizer (SQL Server, MySQL) oder Query Planner (PostgreSQL) übersetzt eine SQL-Anweisung in ein ausführbares Programm (Ausführungsplan).

Generell gibt es zwei Typen:

Regelbasierte Optimizer - Rule Based Optimizer (RBO)

Regelbasierte Optimizer befolgen ein Regelwerk, um einen Ausführungsplan zu erstellen. Zum Beispiel: Wenn möglich, immer einen Index verwenden.

Kostenbasierte Optimizer - Cost Based Optimizer (CBO)

Kostenbasierte Optimizer erstellen alle möglichen Ausführungsplan Varianten, wenden ein Kostenmodell auf jede Variante an und wählen schlussendlich die Variante mit den besten Kosten.

Kostenbasierte Optimizer vergleichen zum Beispiel die Kosten eines Ausführungsplanes mit Index zu denen eines Ausführungsplanes ohne Index (voller Tabellenzugriff). Der Optimizer wählt den vollen Tabellenzugriff, wenn die Kosten besser als beim Index Zugriff sind.

Die meisten Optimizer sind kostenbasierte Optimizer.

Die Hauptaufgaben des Optimizers sind:

  • Die Auswahl des Join Algorithmus und der Join Reihenfolge

  • Die Verwendung von Indizes

Optimizer sind nicht zuständig für:

  • Optimierung von Tabellen oder Indizes

  • Optimierung von verstümmeltem SQL

  • Daten Defragmentierung

Vorherige SeiteNächste Seite

Du kannst nicht alles an einem Tag lernen. Abonniere den Newsletter via E-Mail, Bluesky oder RSS um sukzessive aufzuholen. Und sieh dir auch modern-sql.com an.

Über den Autor

Foto von Markus Winand

Markus Winand gibt auf modern-sql.com Einblick in SQL und zeigt, wie es von verschiedenen Systemen unterstützt wird. Zuvor machte er use-the-index-luke.com, was er noch immer wartet. Markus kann als Trainer, Sprecher und Berater auf winand.at engagiert werden.

Sein Buch kaufen

Titelbild von „SQL Performance Explained“: Eichhörnchen läuft durchs Grass

Die Essenz: SQL-Tuning auf 200 Seiten

Jetzt Kaufen
(Taschenbuch und/oder PDF)

Sein Training

Markus verwandelt veraltetes SQL-92-Wissen in solides und zeitgemäßes SQL-Know-how

Erfahren Sie mehr»

Neuigkeiten Abonnieren

Markus Winands MailinglistenMarkus Winands RSS-FeedMarkus Winand auf LinkedInMarkus Winand auf XINGMarkus Winand auf TwitterMarkus Winand auf Bluesky
Copyright 2010-2025 Markus Winand. Alle Rechte vorbehalten.
Impressum | Kontakt | KEINE GEWÄHR | Handelsmarken | Datenschutz und DSGVO