Inhaltsverzeichnis
MySQL einfacher Index
1. So finden Sie #🎜🎜, wenn es einen gibt kein Index #
#🎜 🎜 #
Heim Datenbank MySQL-Tutorial Einfache MySQL-Indexplananalyse

Einfache MySQL-Indexplananalyse

May 29, 2023 pm 01:16 PM
mysql

    MySQL einfacher Index

    1. So finden Sie #🎜🎜, wenn es einen gibt kein Index #

    Ignorieren Sie vorerst das Konzept des Index. Wenn Sie einen bestimmten Datensatz jetzt direkt überprüfen möchten, wie durchsuchen Sie ihn?

    Suche auf einer Seite
    Wenn die Tabelle nur sehr wenige Datensätze enthält und eine Seite ausreicht, gibt es zwei Situationen:

    #🎜🎜 ## 🎜🎜#

    Verwenden Sie den Primärschlüssel als Suchbedingung: Dies ist die im vorherigen Artikel erwähnte Methode. Verwenden Sie die Dichotomiemethode, um den Slot im Seitenverzeichnis schnell zu finden, und durchsuchen Sie dann die Datensätze, die der Gruppe entsprechen Steckplatz und finden Sie schließlich den angegebenen Datensatz.
    • Andere Nicht-Primärschlüsselspalten als Suchbedingungen verwenden: Da es auf der Datenseite kein Seitenverzeichnis für Nicht-Primärschlüsselspalten gibt, kann der Steckplatz nicht schnell gefunden werden Durch die Dichotomiemethode können Datensätze nur aus Infimum erhalten werden. Beginnen Sie damit, jeden Datensatz der einfach verknüpften Liste gleichzeitig zu durchlaufen, was ineffizient ist.
    • Suche auf vielen Seiten
    Wenn die Tabelle viele Datensätze enthält, werden viele Datenseiten verwendet, um sie zu speichern. Erfordert 2 Schritte :

    Suchen Sie die Seite, auf der sich der Datensatz befindet.
    • Wiederholen Sie den obigen Suchvorgang innerhalb einer Seite.
    • Wenn kein Index vorhanden ist, können wir die Seite, auf der sich der Datensatz befindet, im Allgemeinen nicht schnell finden. Wir können nur der doppelt verknüpften Liste ab der ersten Seite folgen. Die Seite hat die vorherige Seite und die nächste Seite) sucht weiter und wiederholt dann den obigen Vorgang auf jeder Seite, um den angegebenen Datensatz abzufragen, was das Durchlaufen aller Datensätze erfordert, was sehr zeitaufwändig ist.
    2. Ein einfacher Index

    Da die Positionierungsaufzeichnung aufgrund zu vieler Seiten zu langsam ist, wie kann man das Problem lösen? Möglicherweise möchten Sie im „Seitenverzeichnis“ nachschlagen.

    Das Seitenverzeichnis ist so eingerichtet, dass die Position eines Datensatzes auf der Seite anhand des Primärschlüssels schnell ermittelt werden kann. Daher können wir eine Methode zum Erstellen eines „anderen Verzeichnisses“ untersuchen, um schnell die Seite zu finden, auf der sich der Datensatz befindet.

    Aber es müssen zwei Dinge erledigt werden, bevor dieses „andere Verzeichnis“ fertiggestellt werden kann.

    1. Der Primärschlüsselwert des Benutzerdatensatzes auf der nächsten Seite muss größer sein als der der vorherigen Seite.

    Angenommen, jede Datenseite kann bis zu 3 Datensätze enthalten (Eigentlich kann es eine Menge sein), dann fügen Sie jetzt 3 Datensätze in die Tabelle ein, jeder Datensatz hat 3 Spalten c1, c2, c3. Der Einfachheit halber wurde auch das Speicherzeilenformat vereinfacht, so dass nur Schlüsselattribute übrig bleiben. Die virtuellen Datensätze Infimum und Supremum befinden sich am Anfang bzw. am Ende des Benutzerdatensatzes, mit drei Benutzerdatensätzen in der Mitte.

    Fügen Sie zu diesem Zeitpunkt weiterhin 1 Datensatz ein. Im hypothetischen Fall muss mindestens eine neue Seite zugewiesen werden, sodass die beiden Seiten neu zugewiesen und neu angeordnet werden. Einfache MySQL-Indexplananalyse

    Bitte beachten Sie, dass die beiden in roter Schrift angezeigten Datensätze einen neu eingefügten Datensatz mit einem Primärschlüssel von 4 enthalten, der auf einer neuen Seite platziert werden sollte . Um jedoch die Anforderung zu erfüllen, dass der Primärschlüsselwert des Benutzerdatensatzes auf der nächsten Seite größer sein muss als der Primärschlüsselwert des Benutzerdatensatzes auf der vorherigen Seite, können auch Vorgänge wie das Verschieben von Datensätzen ausgeführt werden wird als „Seitenaufteilung“ bezeichnet. Einfache MySQL-Indexplananalyse

    Und warum ist die neue Seite Seite 28 und nicht 11? Da die Seiten auf der Festplatte möglicherweise nicht nebeneinander liegen, stellen sie lediglich eine verknüpfte Listenbeziehung her, indem sie die Nummern der vorherigen Seite und der nächsten Seite beibehalten.

    2. Erstellen Sie einen Verzeichniseintrag für alle Seiten

    Fügen Sie nun weiterhin Daten zur Tabelle hinzu:
    #🎜 🎜 #

    Um einen Datensatz aus mehreren nicht benachbarten Seiten schnell zu finden, muss ein Verzeichnis für sie erstellt werden, da diese Seiten möglicherweise nicht zusammenhängend auf der Festplatte liegen.

    Einfache MySQL-IndexplananalyseJede Seite entspricht einem Verzeichniseintrag. Jeder Verzeichniseintrag enthält:

    Der kleinste Primärschlüsselwert im Benutzerdatensatz der Seite. Die Verwendung von Schlüssel stellt

    • Seitenzahl dar, und page_no stellt

    • dar. Also, nach der Katalogisierung, eine solche Beziehung :

    Also, jetzt möchte ich den Datensatz mit einem Primärschlüsselwert von 20 finden. Konkret gibt es zwei Schritte:

    # 🎜🎜#Verwenden Sie die Dichotomiemethode, um anhand des Verzeichniseintrags schnell festzustellen, dass sich der Datensatz mit einem Primärschlüsselwert von 20 in Verzeichniseintrag 3 befindet und die Seitennummer, auf der er sich befindet, 9 ist. Da Sie wissen, dass es sich auf Seite 9 befindet, wiederholen Sie den vorherigen Ansatz, um den endgültigen Zieldatensatz zu finden. Einfache MySQL-Indexplananalyse

    An diesem Punkt ist eine einfache Lösung abgeschlossen. Das fertige einfache Verzeichnis hat einen Alias ​​namens Index.

    3. Durch den einfachen Index aufgedeckte Probleme

    Der oben genannte einfache Index ist der vom Autor des Originalbuchs erstellte Inhalt, um den Lesern das Verständnis Schritt für Schritt zu erleichtern ist nicht das Indexierungsschema von innodb .

    Schauen Sie sich dann den oben vorgeschlagenen Index an und sehen Sie, welche Probleme es gibt.

    Frage 1:

    InnoDB verwendet Seiten als Grundeinheit für die Speicherplatzverwaltung, was bedeutet, dass nur bis zu 16 KB kontinuierlicher Speicher eingespart werden können.

    Wenn die Tabelle immer mehr Datensätze enthält, wird ein sehr großer kontinuierlicher Speicherplatz benötigt, um alle Verzeichniseinträge aufzunehmen, was für Tabellen mit großen Datenmengen unrealistisch ist.

    Frage 2:

    Wir müssen oft Datensätze hinzufügen, löschen und ändern, was sich auf den gesamten Körper auswirken kann.

    Wenn ich beispielsweise alle Datensätze auf Seite 28 im Bild oben lösche, muss Seite 28 nicht vorhanden sein und Verzeichniseintrag 2 muss nicht vorhanden sein. Zu diesem Zeitpunkt müssen Sie die Verzeichniselemente nach Verzeichniselement 2 nach vorne verschieben.

    Auch wenn es nicht verschoben wird, wird durch das Platzieren von Verzeichniseintrag 2 als redundant in der Verzeichniseintragsliste immer noch viel Speicherplatz verschwendet.

    Das obige ist der detaillierte Inhalt vonEinfache MySQL-Indexplananalyse. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Erklärung dieser Website
    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

    Heiße KI -Werkzeuge

    Undresser.AI Undress

    Undresser.AI Undress

    KI-gestützte App zum Erstellen realistischer Aktfotos

    AI Clothes Remover

    AI Clothes Remover

    Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

    Undress AI Tool

    Undress AI Tool

    Ausziehbilder kostenlos

    Clothoff.io

    Clothoff.io

    KI-Kleiderentferner

    AI Hentai Generator

    AI Hentai Generator

    Erstellen Sie kostenlos Ai Hentai.

    Heiße Werkzeuge

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor

    SublimeText3 chinesische Version

    SublimeText3 chinesische Version

    Chinesische Version, sehr einfach zu bedienen

    Senden Sie Studio 13.0.1

    Senden Sie Studio 13.0.1

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    Dreamweaver CS6

    Dreamweaver CS6

    Visuelle Webentwicklungstools

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    PHPs Fähigkeiten zur Verarbeitung von Big-Data-Strukturen PHPs Fähigkeiten zur Verarbeitung von Big-Data-Strukturen May 08, 2024 am 10:24 AM

    Fähigkeiten zur Verarbeitung von Big-Data-Strukturen: Chunking: Teilen Sie den Datensatz auf und verarbeiten Sie ihn in Blöcken, um den Speicherverbrauch zu reduzieren. Generator: Generieren Sie Datenelemente einzeln, ohne den gesamten Datensatz zu laden, geeignet für unbegrenzte Datensätze. Streaming: Lesen Sie Dateien oder fragen Sie Ergebnisse Zeile für Zeile ab, geeignet für große Dateien oder Remote-Daten. Externer Speicher: Speichern Sie die Daten bei sehr großen Datensätzen in einer Datenbank oder NoSQL.

    Wie verwende ich MySQL-Backup und -Wiederherstellung in PHP? Wie verwende ich MySQL-Backup und -Wiederherstellung in PHP? Jun 03, 2024 pm 12:19 PM

    Das Sichern und Wiederherstellen einer MySQL-Datenbank in PHP kann durch Befolgen dieser Schritte erreicht werden: Sichern Sie die Datenbank: Verwenden Sie den Befehl mysqldump, um die Datenbank in eine SQL-Datei zu sichern. Datenbank wiederherstellen: Verwenden Sie den Befehl mysql, um die Datenbank aus SQL-Dateien wiederherzustellen.

    Wie optimiert man die MySQL-Abfrageleistung in PHP? Wie optimiert man die MySQL-Abfrageleistung in PHP? Jun 03, 2024 pm 08:11 PM

    Die MySQL-Abfrageleistung kann durch die Erstellung von Indizes optimiert werden, die die Suchzeit von linearer Komplexität auf logarithmische Komplexität reduzieren. Verwenden Sie PreparedStatements, um SQL-Injection zu verhindern und die Abfrageleistung zu verbessern. Begrenzen Sie die Abfrageergebnisse und reduzieren Sie die vom Server verarbeitete Datenmenge. Optimieren Sie Join-Abfragen, einschließlich der Verwendung geeigneter Join-Typen, der Erstellung von Indizes und der Berücksichtigung der Verwendung von Unterabfragen. Analysieren Sie Abfragen, um Engpässe zu identifizieren. Verwenden Sie Caching, um die Datenbanklast zu reduzieren. Optimieren Sie den PHP-Code, um den Overhead zu minimieren.

    Wie füge ich mit PHP Daten in eine MySQL-Tabelle ein? Wie füge ich mit PHP Daten in eine MySQL-Tabelle ein? Jun 02, 2024 pm 02:26 PM

    Wie füge ich Daten in eine MySQL-Tabelle ein? Mit der Datenbank verbinden: Stellen Sie mit mysqli eine Verbindung zur Datenbank her. Bereiten Sie die SQL-Abfrage vor: Schreiben Sie eine INSERT-Anweisung, um die einzufügenden Spalten und Werte anzugeben. Abfrage ausführen: Verwenden Sie die Methode query(), um die Einfügungsabfrage auszuführen. Bei Erfolg wird eine Bestätigungsmeldung ausgegeben.

    Wie erstelle ich eine MySQL-Tabelle mit PHP? Wie erstelle ich eine MySQL-Tabelle mit PHP? Jun 04, 2024 pm 01:57 PM

    Das Erstellen einer MySQL-Tabelle mit PHP erfordert die folgenden Schritte: Stellen Sie eine Verbindung zur Datenbank her. Erstellen Sie die Datenbank, falls sie nicht vorhanden ist. Wählen Sie eine Datenbank aus. Tabelle erstellen. Führen Sie die Abfrage aus. Schließen Sie die Verbindung.

    Wie verwende ich gespeicherte MySQL-Prozeduren in PHP? Wie verwende ich gespeicherte MySQL-Prozeduren in PHP? Jun 02, 2024 pm 02:13 PM

    So verwenden Sie gespeicherte MySQL-Prozeduren in PHP: Verwenden Sie PDO oder die MySQLi-Erweiterung, um eine Verbindung zu einer MySQL-Datenbank herzustellen. Bereiten Sie die Anweisung zum Aufrufen der gespeicherten Prozedur vor. Führen Sie die gespeicherte Prozedur aus. Verarbeiten Sie die Ergebnismenge (wenn die gespeicherte Prozedur Ergebnisse zurückgibt). Schließen Sie die Datenbankverbindung.

    So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4 So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4 Dec 09, 2024 am 11:42 AM

    Eine der wichtigsten Änderungen, die in MySQL 8.4 (der neuesten LTS-Version von 2024) eingeführt wurden, besteht darin, dass das Plugin „MySQL Native Password“ nicht mehr standardmäßig aktiviert ist. Darüber hinaus entfernt MySQL 9.0 dieses Plugin vollständig. Diese Änderung betrifft PHP und andere Apps

    Der Unterschied zwischen Oracle-Datenbank und MySQL Der Unterschied zwischen Oracle-Datenbank und MySQL May 10, 2024 am 01:54 AM

    Oracle-Datenbank und MySQL sind beide Datenbanken, die auf dem relationalen Modell basieren, aber Oracle ist in Bezug auf Kompatibilität, Skalierbarkeit, Datentypen und Sicherheit überlegen, während MySQL auf Geschwindigkeit und Flexibilität setzt und eher für kleine bis mittlere Datensätze geeignet ist. ① Oracle bietet eine breite Palette von Datentypen, ② bietet erweiterte Sicherheitsfunktionen, ③ ist für Anwendungen auf Unternehmensebene geeignet; ① MySQL unterstützt NoSQL-Datentypen, ② verfügt über weniger Sicherheitsmaßnahmen und ③ ist für kleine bis mittlere Anwendungen geeignet.

    See all articles