Heim >Datenbank >MySQL-Tutorial >Tutorial zum Erlernen des MySQL-Index_MySQL

Tutorial zum Erlernen des MySQL-Index_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-10-09 08:33:401137Durchsuche

In MySQL können Indizes in zwei Typen unterteilt werden: Hash-Index und Btree-Index.

Unter welchen Umständen kann der B-Tree-Index verwendet werden?

1.Vollwert-Matching-Index

Zum Beispiel:

orderID="123"

2. Übereinstimmung mit dem Präfix-Index ganz links

Zum Beispiel: Erstellen Sie einen gemeinsamen Index für Benutzer-ID- und Datumsfelder.
Wenn Sie dann die Benutzer-ID als Bedingung eingeben, kann die Benutzer-ID im Index verwendet werden. Wenn Sie als Bedingung direkt das Datum eingeben, wird der Index nicht verwendet.

3. Abfrage nach Spaltenpräfixen

Zum Beispiel: order_sn like „134 %“. Dies kann den Index verwenden.

4. Abfrage des passenden Bereichswerts

createTime>'2015-01-09' und createTime<'2015-01-10'

5. Passen Sie die linke vordere Spalte genau an und stimmen Sie den Bereich mit einer anderen Spalte überein

Zum Beispiel:

userId=1 und createTime>'2016-9-18'

6. Eine Abfrage, die nur auf den Index zugreift, wird als abdeckender Index bezeichnet, und der Index enthält die Daten der Abfragespalte.

Einschränkungen des BTREE-Index

1. Wenn die Suche nicht in der Spalte ganz links im Index beginnt, kann der Index nicht verwendet werden.

Erstellen Sie beispielsweise einen gemeinsamen Index:

Die Felder „orderId“ und „createTime“ erstellen einen gemeinsamen Index. Wenn Sie nur die Bedingungen für „createTIme“ ohne die Bedingungen für „orderid“ eingeben, wird dieser Index nicht verwendet.

2. Bei Verwendung eines Index können Sie die indizierten Spalten nicht überspringen.

Drei Spalten:

Datum, Name und Telefonnummer bilden Spalten und Indizes. Wenn Sie bei der Abfrage nur Datum und Telefonnummer eingeben, können Sie das Datum nur als Index zum Filtern verwenden.

3.NOT IN- und <>-Vorgänge können keine Indizes verwenden.

4. Wenn in der Abfrage eine Bereichsabfrage für eine bestimmte Spalte vorhanden ist, können alle Spalten rechts davon den Index nicht verwenden.

Funktionen des Hash-Index

Der Hash-Index wird basierend auf der Hash-Tabelle implementiert. Der Hash-Index kann nur verwendet werden, wenn die Abfragebedingungen genau mit allen Spalten im Hash-Index übereinstimmen. Es kann sich nur um eine äquivalente Abfrage handeln.

Für alle Spalten im Hash-Index berechnet die Speicher-Engine einen Hash-Code für jede Zeile und der Hash-Code wird im Hash-Index gespeichert.

Einschränkungen:

1. Es muss zweimal gelesen werden, zuerst den Hash lesen, um die entsprechende Zeile zu finden, und dann die entsprechenden Zeilendaten lesen.

2.Hash-Index kann nicht zum Sortieren verwendet werden.

3. Es wird nur eine präzise Suche unterstützt, eine Teilindexsuche wird nicht unterstützt und eine Bereichssuche wird nicht unterstützt.

Hash-Konflikt:

Hash-Indizes können nicht für Felder mit schlechter Selektivität verwendet werden, müssen aber zum Erstellen von Hash-Indizes für Spalten mit starker Selektivität verwendet werden.

Zum Beispiel: Erstellen Sie keinen Hash-Index für das Geschlechtsfeld.

Warum Indizes verwenden?

1. Indizes reduzieren die Datenmenge, die die Speicher-Engine scannen muss, erheblich. Der Index ist kleiner als die Datengröße.

2. Indizes können uns beim Sortieren helfen, um die Verwendung temporärer Tabellen zu vermeiden. Indizes sind geordnet.

3. Indizes können zufällige E/A in sequentielle E/A umwandeln

Ist es umso besser, je mehr Indizes vorhanden sind?

1. Indizes erhöhen die Kosten für Schreibvorgänge

2. Zu viele Indizes verlängern die Abfrageoptimierungs- und Auswahlzeit.

Strategie zur Indexierung

1. Ausdrücke oder Funktionen können nicht für Indexspalten verwendet werden

Zum Beispiel: Wählen Sie * aus dem Produkt aus, wobei to_days(out_date) –to_days(current_date)<=30, out_date die Indexspalte ist.

geändert in:

Wählen Sie* aus dem Produkt aus, wobei out_date ist

2. Die Indexgröße darf einen bestimmten Wert nicht überschreiten.
Die Größe der Inodb-Indexspalte beträgt 200 Länge.

3. Selektivität von Präfix- und Indexspalten.

Index idx_NAME für Tabelle (Konto) erstellen;

4. Unionsindex

So wählen Sie die Reihenfolge der Indexspalten aus.

1. Spalten, die häufig indiziert werden.

2. Säulen mit hoher Selektivität erhalten Vorrang.

3. Erstellen Sie Indizes für kleine Spalten.

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