Heim  >  Artikel  >  Backend-Entwicklung  >  MySQL-Indexoptimierung für den Index

MySQL-Indexoptimierung für den Index

小云云
小云云Original
2018-03-22 09:29:531702Durchsuche

Ich bin kürzlich auf ein Problem beim Umgang mit altem Geschäftscode gestoßen. Dieser Artikel teilt Ihnen hauptsächlich den umfassenden Index der MySQL-Indexoptimierung mit.

Ich bin kürzlich auf dieses Beispiel gestoßen, als ich mit altem Geschäftscode gearbeitet habe:

Die Tabellenstruktur ist wie folgt:

CREATE TABLE `group_user` ( 
  `id` int(11) NOT NULL auto_increment, 
  `uid` int(11) NOT NULL, 
  `username` varchar(16) NOT NULL,
  `gid` int(11) NOT NULL, 
  `create_time` int(10) NOT NULL, 
  `update_time` int(10) NOT NULL, 
  PRIMARY KEY  (`id`), 
  KEY `idx_uid` (`uid`), 
  KEY `idx_gid` (`gid`) 
) ENGINE=InnoDB AUTO_INCREMENT=1530312 DEFAULT CHARSET=utf8

150 W Daten, eine solche Aussage:

SELECT SQL_NO_CACHE uid FROM group_user WHERE gid = 2 ORDER BY create_time ASC LIMIT 10;

Es gibt viele langsame Abfrageprotokolle, die 2 Sekunden dauern. Das Ergebnis von Explain ist:

+----+-------------+------------+------+---------------+----------+---------+-------+------+--------------------------------+ 
| id | select_type | table      | type | possible_keys | key      | key_len | ref   | rows | Extra                          | 
+----+-------------+------------+------+---------------+----------+---------+-------+------+--------------------------------+ 
|  1 | SIMPLE      | group_user | ref  | idx_gid       | idx_gid  | 4       | const | 6535 | Using where; Using filesort    | 
+----+-------------+------------+------+---------------+----------+---------+-------+------+--------------------------------+

Aus dem Ergebnis von Explain können wir erkennen, dass die Abfrage den Index verwendet hat. aber warum ist es immer noch so langsam?

Analyse: Erstens verwendet die Anweisung ORDER BY die Dateisortierung, und die Abfrageeffizienz ist gering. Zweitens befindet sich das Abfragefeld nicht im Index und wird daher nicht verwendet Die Datenverteilung muss über den Index zurück zur Tabelle abgefragt werden. Es gibt mehr GIDs, die gleich sind, die UID-Hashes sind relativ gleichmäßig und die Auswirkung der Verwendung nur sekundärer Indizes ist durchschnittlich (falls Sie es nicht wissen). Für die Indexklassifizierung klicken Sie bitte auf: Einführung in die MySQL-Indexklassifizierung.

Lösung: Da nur das UID-Feld abgefragt wird, können durch Hinzufügen eines gemeinsamen Index Tabellenrückgaben und Dateisortierungen vermieden werden. Verwenden Sie den Abdeckindex, um die Abfragegeschwindigkeit zu verbessern, und verwenden Sie den Index, um die Sortierung abzuschließen.

Abgedeckter Index: MySQL muss nur den Index verwenden, um die für die Abfrage erforderlichen Daten zurückzugeben, ohne den Primärschlüssel über den Sekundärindex finden und dann die Daten abfragen zu müssen.

ALTER TABLE group_user ADD INDEX idx_gid_ctime_uid (gid, create_time, uid);

Erklären Sie es noch einmal:

EXPLAIN SELECT SQL_NO_CACHE uid FROM group_user USE INDEX(idx_gid_ctime_uid) WHERE gid = 2 ORDER BY create_time ASC LIMIT 10;
+----+-------------+------------+------+-------------------+-------------------+---------+-------+------+--------------------------+ 
| id | select_type | table      | type | possible_keys     | key               | key_len | ref   | rows | Extra                    |
+----+-------------+------------+------+-------------------+-------------------+---------+-------+------+--------------------------+
|  1 | SIMPLE      | group_user | ref  | idx_gid_ctime_uid | idx_gid_ctime_uid | 4       | const | 6375 | Using where; Using index |
+----+-------------+------------+------+-------------------+-------------------+---------+-------+------+--------------------------+

Zusätzliche Informationen enthalten bereits „Using Index“, was darauf hinweist, dass ein abdeckender Index verwendet wurde (normalerweise gibt es viele Kollegen, die SELECT * , was eine Falle ist).

Warum muss in der Anweisung manuell angegeben werden, welcher Index verwendet werden soll? Weil der MySQL-Abfrageoptimierer möglicherweise den idx_gid-Index verwendet, sofern er nicht gelöscht wird.

Nach der Indexoptimierung überschreiten Online-Abfragen grundsätzlich nicht mehr als 0,001 Sekunden.

Letzte Frage: Wie wird die tatsächliche Situation aussehen, wenn diese Tabelle die MyISAM-Engine verwendet?

Verwandte Empfehlungen:

MySQL-Indexoptimierungsmethode

So verwenden Sie die MySQL-Indexoptimierung

MySQL-Optimierung: tiefgehendes Verständnis von Speicher-Engines und Indexoptimierung

Das obige ist der detaillierte Inhalt vonMySQL-Indexoptimierung für den Index. 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