Heim >häufiges Problem >Es gibt verschiedene Arten von Indizes in Oracle

Es gibt verschiedene Arten von Indizes in Oracle

DDD
DDDOriginal
2023-06-05 16:13:175957Durchsuche

Oracle verfügt über sechs Arten von Indizes, nämlich: 1. B*-Baumindex, der wie ein Binärbaum strukturiert ist und basierend auf dem Schlüssel schnellen Zugriff auf eine Zeile oder eine Reihe von Zeilen ermöglichen kann; . Bitmap-Index, geeignet für sich stark wiederholende und normalerweise schreibgeschützte Daten. 3. Funktionsbasierter Index, der das Ergebnis einer Funktionsberechnung in der Spalte der Zeile speichern kann. 4. Anwendungsdomänenindex, der von erstellt und gespeichert wird selbst; 5. HASH-Index, muss zur Verwendung des HASH-Clusters einfach in mehrere Fragmente unterteilt werden.

Es gibt verschiedene Arten von Indizes in Oracle

Die Betriebsumgebung dieses Artikels: Windows 10-System, Oracle Version 19c, Dell g3-Computer.

Oracle stellt sechs verschiedene Arten von Indizes zur Verwendung bereit.

Oracle enthält die folgenden Indizes:

1, B*-Baumindex

Davon spreche ich über den Index „Traditionell“. Dies ist bei weitem der am häufigsten verwendete Index in Oracle und den meisten anderen Datenbanken.

B* Der Baum ist ähnlich einem Binärbaum aufgebaut und kann basierend auf dem Schlüssel einen schnellen Zugriff auf eine Zeile oder eine Reihe von Zeilen ermöglichen, wobei normalerweise nur wenige Lesevorgänge erforderlich sind, um die richtige Zeile zu finden. Es ist jedoch wichtig zu beachten, dass das „B“ im „B*-Baum“ nicht für binär, sondern für ausgeglichen steht. Ein B*-Baumindex ist kein Binärbaum, wie Sie erfahren werden, wenn wir vorstellen, wie man einen B*-Baum physisch auf der Festplatte speichert. B*-Baumindizes haben die folgenden Untertypen:

Indexorganisierte Tabelle (indexorganisierte Tabelle): Indexorganisierte Tabellen werden in einer B*-Baumstruktur gespeichert. Im Gegensatz zu Heap-Tabellen, in denen Datenzeilen unorganisiert gespeichert werden (Daten können platziert werden, solange Platz verfügbar ist), werden Daten in IOT in der Reihenfolge der Primärschlüssel gespeichert und sortiert. Für die Anwendung verhält sich das IOT wie eine „normale“ Tabelle; für den korrekten Zugriff auf das IOT ist SQL erforderlich. IOT ist am nützlichsten für die Informationserfassung, räumliche Systeme und OLAP-Anwendungen. IoT wurde im vorherigen Kapitel ausführlich besprochen.

B*tree-Cluster-Index (B*tree-Cluster-Index) Dies ist eine Variante des traditionellen B*tree-Index (mit nur geringfügigen Änderungen). B*-Tree-Clustered-Indizes werden zur Indizierung von Cluster-Schlüsseln verwendet (siehe Abschnitt „Indizierung von Cluster-Tabellen“ in Kapitel 11), daher werden sie in diesem Kapitel nicht behandelt. In herkömmlichen B*-Bäumen verweisen Schlüssel auf eine Zeile; im Gegensatz zum B*-Baum-Clustering zeigt ein Clustering-Schlüssel auf einen Block, der mehrere Zeilen enthält, die sich auf diesen Clustering-Schlüssel beziehen.

Absteigender Index: Der absteigende Index ermöglicht das Sortieren von Daten in der Indexstruktur in der Reihenfolge „von groß nach klein“ (absteigende Reihenfolge) und nicht in der Reihenfolge „klein nach groß“ (aufsteigende Reihenfolge). Wir erklären, warum absteigende Indizes wichtig sind und wie absteigende Indizes funktionieren.

Reverse-Key-Index (Reverse-Key-Index): Dies ist auch ein B*-Baum-Index, außer dass die Bytes im Schlüssel „umgekehrt“ werden. Bei einem invertierten Schlüsselindex können Indexeinträge gleichmäßiger im Index verteilt werden, wenn der Index mit aufsteigenden Werten gefüllt wird. Wenn Sie beispielsweise eine Sequenz zum Generieren eines Primärschlüssels verwenden, generiert die Sequenz Werte wie 987500, 987501, 987502 usw. Die Werte sind sequentiell. Wenn also ein herkömmlicher B*-Baumindex verwendet würde, könnten diese Werte im selben rechten Block platziert werden, was die Konkurrenz für diesen Block erhöht. Mit dem umgekehrten Schlüssel indiziert Oracle logisch 205789, 105789, 005789 usw. Oracle wird die gespeicherten Daten byte-umkehren, bevor sie in den Index eingefügt werden, sodass Werte, die ursprünglich im Index möglicherweise nebeneinander lagen, nach der Byte-Umkehr weit voneinander entfernt sind. Durch die Umkehrung der Bytes werden Einfügungen in den Index über mehrere Blöcke verteilt.

2. Bitmap-Index (Bitmap-Index)

In einem B*-Baum besteht normalerweise eine Eins-zu-Eins-Beziehung zwischen Indexeinträgen und Zeilen: a Der Indexeintrag zeigt auf eine Zeile. Bei Bitmap-Indizes verwendet ein Indexeintrag eine Bitmap, um gleichzeitig auf mehrere Zeilen zu verweisen. Bitmap-Indizes eignen sich für Daten, die sich stark wiederholen und normalerweise schreibgeschützt sind (stark repetitiv bedeutet, dass die Daten im Verhältnis zur Gesamtzahl der Zeilen in der Tabelle nur wenige unterschiedliche Werte haben). Stellen Sie sich eine Tabelle mit 1 Million Zeilen vor, in der jede Spalte nur drei mögliche Werte hat: Y, N und NULL. Wenn Sie beispielsweise häufig zählen müssen, wie viele Zeilen den Wert Y haben, eignet sich dies zum Erstellen eines Bitmap-Index. Dies bedeutet jedoch nicht, dass kein Bitmap-Index erstellt werden kann, wenn eine Spalte in dieser Tabelle 11.000 verschiedene Werte enthält. Natürlich kann auch für diese Spalte ein Bitmap-Index erstellt werden. In einer OLTP-Datenbank können Bitmap-Indizes aufgrund von Parallelitätsproblemen nicht berücksichtigt werden (wir werden später darauf eingehen). Beachten Sie, dass für Bitmap-Indizes Oracle Enterprise oder Personal Edition erforderlich ist.

Bitmap-Join-Index (Bitmap-Join-Index): Dies stellt eine Denormalisierungsmethode für Daten in einer Indexstruktur (anstelle einer Tabelle) bereit. Betrachten Sie beispielsweise die einfachen EMP- und DEPT-Tabellen. Jemand könnte diese Frage stellen: „Wie viele Personen arbeiten in der Abteilung in Boston?“ Um die Anzahl der Mitarbeiter in der Abteilung mit dem LOC-Wert Boston zu zählen, müssen Sie normalerweise a ausfüllen Tabellenverknüpfungen und LOC-Spaltenverknüpfungen mit EMP-Datensätzen zur Beantwortung dieser Frage. Mithilfe eines Bitmap-Join-Index können Sie die LOC-Spalte in der EMP-Tabelle indizieren.

3. Funktionsbasierter Index

Dies sind B*-Baumindizes oder Bitmap-Indizes, die das Ergebnis einer Funktionsberechnung in der Spalte der Zeile speichern, anstatt die Spaltendaten selbst zu speichern . Sie können sich einen funktionsbasierten Index als einen Index für eine virtuelle Spalte (oder abgeleitete Spalte) vorstellen; mit anderen Worten: Die Spalte wird nicht physisch in der Tabelle gespeichert. Funktionsbasierte Indizes können verwendet werden, um Abfragen wie SELECT * FROM T W HERE FUNCTION(DATABASE_COLUMN) = SAME_VALUE zu beschleunigen, da der Wert FUNCTION(DATABASE_COLUMN) im Voraus berechnet und im Index gespeichert wurde.

4. Anwendungsdomänenindex (Anwendungsdomänenindex)

Der Anwendungsdomänenindex ist ein Index, den Sie selbst erstellen und speichern. Er kann in Oracle oder außerhalb von Oracle gespeichert werden. . Sie müssen dem Optimierer mitteilen, wie selektiv der Index ist und wie teuer die Ausführung ist, und der Optimierer entscheidet anhand der von Ihnen bereitgestellten Informationen, ob er Ihren Index verwendet. Oracle-Textindizes sind ein Beispiel für einen Anwendungsdomänenindex. Sie können auch Ihre eigenen Indizes mit denselben Tools erstellen, die Sie zum Erstellen von Oracle-Textindizes verwenden. Es sei darauf hingewiesen, dass der hier erstellte „Index“ nicht die Verwendung einer herkömmlichen Indexstruktur erfordert. Beispielsweise verwenden Oracle-Textindizes eine Reihe von Tabellen, um ihre Indexkonzepte zu implementieren.

5. HASH-Index

Um den HASH-Index zu verwenden, müssen Sie einen HASH-Cluster verwenden. Wenn Sie einen Cluster oder HASH-Cluster erstellen, definieren Sie auch einen Clusterschlüssel. Dieser Schlüssel teilt Oracle mit, wie die Tabelle im Cluster gespeichert werden soll. Beim Speichern von Daten werden alle Zeilen, die sich auf diesen Clusterschlüssel beziehen, in einem Datenbankblock gespeichert. Wenn die Daten im selben Datenbankblock gespeichert sind und ein HASH-Index verwendet wird, kann Oracle auf die Daten zugreifen, indem es eine HASH-Funktion und E/A ausführt – und indem es einen B-Tree-Index der Binärhöhe 4 anwendet, den Sie verwenden müssen 4 I/O beim Abrufen der Daten.

Tipp: Der HASH-Index ist sehr nützlich, wenn Einschränkungen bestehen (die Angabe eines bestimmten Werts anstelle eines Wertebereichs ist erforderlich).

6. Partitionierter Index

Ein partitionierter Index unterteilt einfach einen Index in mehrere Fragmente, sodass auf kleinere Fragmente zugegriffen werden kann und diese Fragmente unterschiedlich auf der Festplatte gespeichert werden können (um E/A-Probleme zu vermeiden). Sowohl B-Nummern-Indizes als auch Bitmap-Indizes können partitioniert werden, HASH-Indizes können jedoch nicht partitioniert werden.

Es gibt zwei Arten von partitionierten Indizes: lokale partitionierte Indizes und globale partitionierte Indizes. Jeder Typ hat zwei Untertypen: mit Präfix und ohne Präfix. Wenn ein Bitmap-Index verwendet wird, muss es sich um einen lokalen Index handeln.

Der Hauptgrund für die Partitionierung des Index besteht darin, die Größe des zu lesenden Index zu reduzieren. Darüber hinaus kann die Platzierung der Partitionen in verschiedenen Tabellenbereichen die Verfügbarkeit und Zuverlässigkeit der Partitionen verbessern.

Das obige ist der detaillierte Inhalt vonEs gibt verschiedene Arten von Indizes in Oracle. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn