Indexe – Übersicht

Nur für die Cloud Firestore Enterprise-Edition relevant.

Auf dieser Seite wird die Indexierung für Cloud Firestore mit MongoDB-Kompatibilität beschrieben. Bei Cloud Firestore mit MongoDB-Kompatibilität werden standardmäßig keine Indexe erstellt. Um die Datenbankleistung zu verbessern, erstellen Sie Indexe für Ihre am häufigsten verwendeten Abfragen.

Indexe haben einen großen Einfluss auf die Leistung einer Datenbank. Wenn ein Index für eine Abfrage vorhanden ist, kann die Datenbank effizient Ergebnisse zurückgeben, indem die Menge der zu scannenden Daten und der Aufwand zum Sortieren der Ergebnisse reduziert werden. Indexeinträge erhöhen jedoch die Speicherkosten und den Arbeitsaufwand bei Schreibvorgängen für indexierte Felder.

Indexdefinition und -struktur

Ein Index besteht aus Folgendem:

  • eine Sammlungs-ID
  • eine Liste der Felder in der angegebenen Sammlung
  • eine aufsteigende oder absteigende Reihenfolge für jedes Feld

Ein Index kann auch die Optionen sparse, multikey oder unique aktivieren.

Indexreihenfolge

Die Reihenfolge und Sortierrichtung der einzelnen Felder definieren den Index eindeutig. Die folgenden Indexe sind beispielsweise zwei unterschiedliche Indexe und nicht austauschbar:

Sammlung Felder
Städte Land (aufsteigend), Bevölkerung (absteigend)
Städte Bevölkerung (absteigend), Land (aufsteigend)

Wenn Sie einen Index zur Unterstützung einer Abfrage erstellen, müssen Sie die Felder in derselben Reihenfolge wie in der Abfrage angeben.

Indexdichte

Standardmäßig werden in Indexeinträgen Daten aus allen Dokumenten in einer Sammlung gespeichert. Das wird als nicht spärlicher Index bezeichnet. Für ein Dokument wird ein Indexeintrag hinzugefügt, unabhängig davon, ob das Dokument eines der im Index angegebenen Felder enthält. Nicht vorhandene Felder werden beim Generieren von Indexeinträgen so behandelt, als hätten sie einen NULL-Wert. Um dieses Verhalten zu ändern, können Sie den Index als Sparse-Index definieren.

Dünnbesetzte Indexe

Ein dünnbesetzter Index indexiert nur die Dokumente in der Sammlung, die einen Wert (einschließlich Null) für mindestens eines der indexierten Felder enthalten. Ein Sparse-Index senkt die Speicherkosten und kann die Leistung verbessern.

Indexe mit mehreren Schlüsseln für Arraywerte

Wenn Sie einen Index für ein Feld mit Arraywerten erstellen, müssen Sie einen Index mit mehreren Schlüsseln erstellen. Mit einem regulären Index können keine Arraywerte indexiert werden. Ein Index mit mehreren Schlüsseln unterstützt bis zu einem Arrayfeld in der Indexdefinition und kann für Vorgänge verwendet werden, die Arraywerte durchlaufen.

Verwenden Sie Indexe mit mehreren Schlüsseln nur, wenn Sie Arraywerte indexieren müssen. Reguläre Indexe haben Vorteile bei der Verarbeitung einer Abfrage. Mit regulären Indexen lassen sich Werte in einem Bereich beispielsweise effizienter filtern.

Die folgenden Situationen führen zu Fehlern bei der Arbeit mit Arraywerten und Indexen mit mehreren Schlüsseln:

  • Bei einem Vorgang wird versucht, einem Feld, das durch einen regulären Index indexiert wird, einen Arraywert hinzuzufügen. Wenn Sie den Array-Wert hinzufügen möchten, müssen Sie die vorhandenen regulären Indexe für dieses Feld löschen und als Multikey-Indexe neu erstellen.
  • Sie versuchen, einen regulären Index für ein Feld zu erstellen, das einen Arraywert enthält. Sie müssen entweder einen Index mit mehreren Schlüsseln erstellen oder die Arraywerte löschen.
  • Bei einem Vorgang wird versucht, mehrere Felder mit Arraywerten zu indexieren. In einem Index mit mehreren Schlüsseln darf es nur ein Feld mit einem Arraywert geben. Ändern Sie Ihr Datenmodell oder Ihre Indexdefinitionen, um fortzufahren.
  • Sie versuchen, einen Index mit mehreren Schlüsseln zu erstellen, bei dem zwei Feldpfade ein gemeinsames Präfix haben, z. B. users.posts und users.zip.

Eindeutige Indexe

Legen Sie die Option für eindeutige Indexe fest, um eindeutige Werte für die indexierten Felder zu erzwingen. Bei Indexen für mehrere Felder muss jede Kombination von Werten im Index eindeutig sein. Die Datenbank lehnt alle Aktualisierungs- und Einfügevorgänge ab, bei denen versucht wird, Indexeinträge mit doppelten Werten zu erstellen. Wenn die Daten der indexierten Felder doppelte Werte enthalten und Sie versuchen, einen eindeutigen Index zu erstellen, schlägt der Indexaufbau mit einer Fehlermeldung in den Vorgangsdetails fehl.

Fehlende Felder in einem eindeutigen Index

Wenn Sie ein Dokument mit fehlenden Feldern für den eindeutigen Index einfügen, werden für die fehlenden Felder null-Werte festgelegt. Der resultierende Indexeintrag muss eindeutig sein, sonst schlägt der Vorgang fehl.

Beispiel:

db.cities.createIndex( { "name": 1 }, { unique: true } )

Wenn Sie das Dokument {"abbreviation": "LA"} der Sammlung hinzufügen, wird durch den eindeutigen Index ein Eintrag mit name auf null erstellt. Wenn Sie dann versuchen, das Dokument {"abbreviation": "NYC"} hinzuzufügen, schlägt der Vorgang fehl, da der resultierende Eintrag für den eindeutigen Index derselbe ist.

Das gleiche Verhalten gilt für eindeutige Indexe mit mehreren Feldern. Beim Erstellen oder Aktualisieren eines Dokuments werden fehlende indexierte Felder auf null gesetzt und der resultierende Indexeintrag muss im Index eindeutig sein.

Fehler bei der Indexerstellung beheben

Bei der Verwaltung von Indexen kann es zu Fehlern der Indexerstellung kommen. Ein Indexierungsvorgang kann fehlschlagen, wenn in der Datenbank ein Problem mit den Daten auftritt. Indexierungsvorgänge können aus folgenden Gründen fehlschlagen:

  • Sie haben ein Indexlimit erreicht. Beispielsweise hat der Vorgang möglicherweise die maximale Anzahl von Indexeinträgen pro Dokument erreicht. Wenn die Indexerstellung fehlschlägt, wird eine Fehlermeldung angezeigt. Wenn Sie kein Indexlimit erreicht haben, wiederholen Sie den Indexierungsvorgang.
  • Ein Index mit mehreren Schlüsseln ist erforderlich. Mindestens eines der indexierten Felder enthält einen Arraywert. Um fortzufahren, müssen Sie entweder einen Index mit mehreren Schlüsseln verwenden oder die Arraywerte löschen.
  • Bei einem Vorgang wird versucht, mehrere Felder mit Arraywerten zu indexieren. In einem Index mit mehreren Schlüsseln darf es nur ein Feld mit einem Arraywert geben. Ändern Sie Ihr Datenmodell oder Ihre Indexdefinitionen, um fortzufahren.
  • Sie haben die Option für den eindeutigen Index festgelegt und die Daten der indexierten Felder würden doppelte Indexeinträge erstellen. Entfernen Sie doppelte Kombinationen von Werten aus den Daten, um fortzufahren.

Nächste Schritte