Heim >Datenbank >MySQL-Tutorial >Sollten Sie boolesche Felder indizieren? Wann macht es einen Unterschied?
Indizierung boolescher Felder für verbesserte Leistung
Abfragen beinhalten oft das Filtern von Daten basierend auf booleschen Feldern. Da boolesche Felder normalerweise als einzelnes Bit oder Byte gespeichert werden, wird allgemein angenommen, dass ihre Indizierung zu einem vernachlässigbaren Leistungsgewinn führen würde. In bestimmten Szenarien kann die Indizierung boolescher Felder jedoch die Abfrageeffizienz erheblich verbessern.
Wenn die Indizierung eines booleschen Felds die Leistung steigert
Die Indizierung eines booleschen Felds ist vorteilhaft, wenn:
Beweise aus realen Beispielen
Ein Benutzer berichteten von einer erheblichen Leistungssteigerung durch die Indizierung eines booleschen Felds. In ihrem Fall hatte eine Tabelle mit 4 Millionen Zeilen ungefähr 1000 Zeilen mit gesetztem booleschen Flag. Die Ausführung der Abfrage mit WHERE isok=1 dauerte über 9 Sekunden. Nach dem Hinzufügen eines Index für das boolesche Feld reduzierte sich die Abfragezeit auf den Bruchteil einer Sekunde.
Fazit
Während die Indizierung boolescher Felder im Allgemeinen nicht empfohlen wird, gibt es solche bestimmte Szenarien, in denen die Abfrageleistung verbessert werden kann. Wenn die Datenverteilung verzerrt ist oder die Abfrageselektivität gering ist, kann die Indizierung eines booleschen Felds zu einer Verbesserung der Abfrageausführungszeit um Größenordnungen führen.
Das obige ist der detaillierte Inhalt vonSollten Sie boolesche Felder indizieren? Wann macht es einen Unterschied?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!