Heim Datenbank MySQL-Tutorial Zusammenfassung der MySQL-Datenbankoptimierungsvorgänge

Zusammenfassung der MySQL-Datenbankoptimierungsvorgänge

Apr 26, 2017 pm 02:19 PM

Dieser Artikel führt Sie hauptsächlich in die allgemeinen Optimierungsvorgänge von MySQL-Datenbanken ein. Der Artikel fasst meine täglichen Erfahrungen bei der Entwicklung und Verwendung von MySQL-Datenbanken zusammen, einschließlich der Verwendung von weniger SELECT*, EXPLAIN SELECT und dem Aktivieren des Abfragecaches wird für alle, die es brauchen, einen gewissen Referenzwert haben.

Vorwort

Für eine datenzentrierte Anwendung wirkt sich die Qualität der Datenbank direkt auf die Leistung des Programms aus, daher ist die Datenbankleistung entscheidend wichtig. Daher muss jeder die Optimierungsoperationen der MySQL-Datenbank verstehen. In diesem Artikel werden hauptsächlich die allgemeinen Optimierungsoperationen in der MySQL-Datenbank zusammengefasst. Ich werde im Folgenden nicht näher darauf eingehen.

1. Index

Natürlich haben wir diese Optimierungsmethode stillschweigend verwendet Es ist der Primärschlüssel Index. Manchmal ist es uns egal, ob ein geeigneter Index definiert ist, die Leistung (Geschwindigkeit) der Datenbankabfrage wird um ein Vielfaches oder sogar Dutzende Male verbessert.

Der normale Index

wird verwendet, um die Abfragegeschwindigkeit zu verbessern.

Tabelle erstellen, Index erstellen

CREATE TABLE tbl_name(
字段名称 字段类型 [完整性约束条件],
~
index [索引名] (column_name)
);
Nach dem Login kopieren

Index erstellen

CREATE INDEX index_name ON tab_name (column_name)
Nach dem Login kopieren

Index löschen

DROP INDEX index_name FROM tab_name
Nach dem Login kopieren

Index anzeigen

SHOW index FROM tab_name
Nach dem Login kopieren

Primärschlüsselindex

Die Aufgabe besteht darin, Abfragen und eindeutige Einschränkungen zu beschleunigen

Tabellen erstellen und Indizes erstellen

CREATE TABLE tbl_name(
字段名称 字段类型 [完整性约束条件],
~
PRIMARY KEY(column_name)
);
Nach dem Login kopieren

Indizes erstellen

ALTER TABLE tab_name ADD PRIMARY KEY(column_name)
Nach dem Login kopieren

Index löschen

ALTER TABLE tab_name DROP PRIMAY KEY(column_name)
Nach dem Login kopieren

Eindeutiger Index

Die Funktion besteht darin, Abfragen und eindeutige Einschränkungen zu beschleunigen

Tabellen erstellen und Indizes erstellen

CREATE TABLE tbl_name(
字段名称 字段类型 [完整性约束条件],
~
unique [索引名] (column_name)
);
Nach dem Login kopieren

Index erstellen

CREATE UNIQUE INDEX index_name ON tab_name (column_name)
Nach dem Login kopieren

Index löschen

DROP UNIQUE INDEX index_name FROM tab_name
Nach dem Login kopieren

2. Weniger SELECT* verwenden

Wenn einige Leute die Datenbank abfragen, wählen sie möglicherweise aus, was sie abfragen möchten. Dies ist ein unangemessenes Verhalten. Wir sollten die Daten erhalten, die wir verwenden möchten, nicht alle, denn wenn wir sie auswählen, erhöht sich die Belastung des Webservers, die Belastung der Netzwerkübertragung steigt und die Abfragegeschwindigkeit nimmt natürlich ab.

3. EXPLAIN SELECT

Es wird geschätzt, dass viele Menschen diese Funktion noch nie gesehen haben, es wird jedoch dringend empfohlen, sie zu verwenden. EXPLAIN zeigt, wie MySQL Indizes verwendet, um Select-Anweisungen zu verarbeiten und Tabellen zu verknüpfen. Kann dabei helfen, bessere Indizes auszuwählen und optimiertere Abfrageanweisungen zu schreiben. Die Hauptverwendung besteht darin, „explain“ vor „select“ hinzuzufügen.

EXPLAIN SELECT [查找字段名] FROM tab_name ...
Nach dem Login kopieren

4. Abfrage-Cache aktivieren

Auf den meisten MySQL-Servern ist der Abfrage-Cache aktiviert. Dies ist eine der effektivsten Möglichkeiten zur Leistungsverbesserung und wird von der MySQL-Datenbank-Engine verwaltet. Wenn viele der gleichen Abfragen mehrmals ausgeführt werden, werden die Abfrageergebnisse in einem Cache abgelegt, sodass nachfolgende identische Abfragen die Tabelle nicht bedienen müssen, sondern direkt auf die zwischengespeicherten Ergebnisse zugreifen.

Der erste Schritt besteht darin, query_cache_type auf ON zu setzen und dann zu prüfen, ob die Systemvariable have_query_cache verfügbar ist:

show variables like 'have_query_cache'
Nach dem Login kopieren

Danach weisen Sie dem Abfragecache Speichergröße zu und Steuern Sie die maximale Größe der zwischengespeicherten Abfragewerte. Relevante Vorgänge werden in der Konfigurationsdatei geändert.

5. Verwenden Sie NOT NULL

Viele Tabellen enthalten Spalten, die NULL (Nullwert) sein können, auch wenn die Anwendung dies nicht muss Speichern Sie sie. Das Gleiche gilt für NULL, da es die Standardeigenschaft einer Spalte ist, NULL zuzulassen. Normalerweise ist es am besten, Spalten als NOT NULL anzugeben, es sei denn, Sie müssen wirklich NULL-Werte speichern.

Abfragen, die NULL-fähige Spalten enthalten, sind schwieriger für MySQL zu optimieren, da NULL-fähige Spalten Indizes, Indexstatistiken und Wertvergleiche komplexer machen. Spalten, die NULL sein können, benötigen mehr Speicherplatz und erfordern eine spezielle Behandlung in MySQL. Wenn NULL-fähige Spalten indiziert werden, erfordert jeder Indexdatensatz ein zusätzliches Byte, was in MyISAM sogar dazu führen kann, dass ein Index fester Größe (z. B. ein Index mit nur einer Ganzzahlspalte) zu einem Index variabler Größe wird.

Normalerweise bringt das Ändern der NULL-Spalte in NOT NULL nur eine geringe Leistungsverbesserung, sodass (bei der Optimierung) keine Notwendigkeit besteht, diese Situation zuerst im vorhandenen Schema zu suchen und zu ändern, es sei denn, Sie sind sicher, dass dies dazu führt ein Problem. Wenn Sie jedoch vorhaben, einen Index für eine Spalte zu erstellen, sollten Sie vermeiden, die Spalte als NULL zu gestalten. Natürlich gibt es Ausnahmen. Erwähnenswert ist beispielsweise, dass InnoDB ein separates Bit zum Speichern von NULL-Werten verwendet, sodass es eine gute Speicherplatzeffizienz für spärliche Daten bietet. Dies gilt jedoch nicht für MyISAM.

6. Auswahl der Speicher-Engine

Was die Auswahl von MyISAM und InnoDB betrifft: Wenn Sie Transaktionsverarbeitung oder Fremdschlüssel benötigen, dann kann InnoDB dies tun ist ein besserer Weg. Wenn Sie eine Volltextindizierung benötigen, ist MyISAM normalerweise eine gute Wahl, da es in das System integriert ist. Wir testen jedoch nicht sehr oft 2 Millionen Datensatzzeilen. Auch wenn es etwas langsamer ist, können wir mit Sphinx einen Volltextindex von InnoDB erhalten.

数据的大小,是一个影响你选择什么样存储引擎的重要因素,大尺寸的数据集趋向于选择InnoDB方式,因为其支持事务处理和故障恢复。数据库的在小决定了故障恢复的时间长短,InnoDB可以利用事务日志进行数据恢复,这会比较快。而MyISAM可能会需要

几个小时甚至几天来干这些事,InnoDB只需要几分钟。

您操作数据库表的习惯可能也会是一个对性能影响很大的因素。比如: COUNT() 在 MyISAM表中会非常快,而在InnoDB表下可能会很痛苦。而主键查询则在InnoDB下会相当相当的快,但需要小心的是如果我们的主键太长了也会导致性能问题。大批的inserts语句在MyISAM下会快一些,但是updates在InnoDB 下会更快一些——尤其在并发量大的时候。

所以,到底你检使用哪一个呢?根据经验来看,如果是一些小型的应用或项目,那么MyISAM也许会更适合。当然,在大型的环境下使用MyISAM也会有很大成功的时候,但却不总是这样的。如果你正在计划使用一个超大数据量的项目,而且需要事务处理或外键支持,那么你真的应该直接使用InnoDB方式。但需要记住InnoDB的表需要更多的内存和存储,转换100GB的MyISAM 表到InnoDB 表可能会让你有非常坏的体验。

七、避免在 where 子句中使用 or 来连接

如果一个字段有索引,一个字段没有索引,将导致引擎放弃使用索引而进行全表扫描,如:

select id from t where num=10 or Name = 'admin'
Nach dem Login kopieren

可以这样查询:

select id from t where num = 10
union all
select id from t where Name = 'admin'
Nach dem Login kopieren

八、多使用varchar/nvarchar

使用varchar/nvarchar代替 char/nchar ,因为首先变长字段存储空间小,可以节省存储空间,其次对于查询来说,在一个相对较小的字段内搜索效率显然要高些。

九、避免大数据量返回

这里要考虑使用limit,来限制返回的数据量,如果每次返回大量自己不需要的数据,也会降低查询速度。

十、where子句优化

where 子句中使用参数,会导致全表扫描,因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推迟到运行时;它必须在编译时进行选择。然 而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。

应尽量避免在 where 子句中对字段进行表达式操作,避免在where子句中对字段进行函数操作这将导致引擎放弃使用索引而进行全表扫描。不要在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算,否则系统将可能无法正确使用索引。

Das obige ist der detaillierte Inhalt vonZusammenfassung der MySQL-Datenbankoptimierungsvorgänge. 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ßer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

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)

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 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 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.

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

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.

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.

C++-Programmoptimierung: Techniken zur Reduzierung der Zeitkomplexität C++-Programmoptimierung: Techniken zur Reduzierung der Zeitkomplexität Jun 01, 2024 am 11:19 AM

Die Zeitkomplexität misst die Ausführungszeit eines Algorithmus im Verhältnis zur Größe der Eingabe. Zu den Tipps zur Reduzierung der Zeitkomplexität von C++-Programmen gehören: Auswahl geeigneter Container (z. B. Vektor, Liste) zur Optimierung der Datenspeicherung und -verwaltung. Nutzen Sie effiziente Algorithmen wie die schnelle Sortierung, um die Rechenzeit zu verkürzen. Eliminieren Sie mehrere Vorgänge, um Doppelzählungen zu reduzieren. Verwenden Sie bedingte Verzweigungen, um unnötige Berechnungen zu vermeiden. Optimieren Sie die lineare Suche, indem Sie schnellere Algorithmen wie die binäre Suche verwenden.

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