


Entwicklung von Hochleistungs-MySql (2): Optimierung von Datentypen_Teil 2
· BLOB/TEXT
In tatsächlichen Anwendungen ist es oft notwendig, zwei Arten größerer Daten zu speichern, z. B. ein 10-Megapixel-Bild, und die andere ist größerer Text, z. B. ein Artikel von Zehntausenden von Wörtern. In Oracle gibt es BOLB und CLOB für den Umgang mit diesen beiden Datentypen, während sie in MySQL BLOB und TEXT entsprechen.
Aufgrund der Besonderheit dieser beiden Datentypen sind die Speicherung und der Betrieb von BLOB und TEXT identisch erfolgt in MySQL.
1) BLOB/TEXT-Werte werden oft als Objekte behandelt.
2) Wenn BLOB/TEXT-Werte zum Sortieren verwendet werden , es werden nur die ersten N Bytes verwendet, N entspricht einem konstanten Wert in der Datenbank (max_sort_length). Wenn Sie mehr Bytes angeben möchten, die zum Sortieren verwendet werden sollen, können Sie den Wert von max_sort_length erhöhen oder ORDER BY SUBSTRING( Spalte, Länge) zu verarbeitende Funktion
3) Wenn BLOB/TEXT zum Indizieren oder Sortieren verwendet wird, kann nicht der Wert des gesamten Felds verwendet werden
Vermeiden Sie die Verwendung von BOLB/TEXT als letzten Ausweg zum Indizieren oder Sortieren
Da die Speicher-Engine von MySQL die Typen BLOB und TEXT nicht unterstützt, müssen Sie, wenn BLOB /TEXT am Abfrageprozess beteiligt ist, eine temporäre MyISAM-Festplattentabelle verwenden, auch wenn nur wenige Datenzeilen vorhanden sind true (die Speicher-Engine im neuesten Percona Server unterstützt BLOB- und TEXT-Typen).
Der häufige Zugriff der Speicher-Engine auf temporäre Festplattentabellen führt zu einem erheblichen Leistungsaufwand. Die beste Lösung besteht darin, die Verwendung von BLOB- und TEXT-Typen so weit wie möglich zu vermeiden. Wenn Sie dies nicht vermeiden können, besteht ein Trick darin, SUBSTRING(column, length) überall dort zu verwenden, wo ein BLOB-Feld verwendet wird, um den Spaltenwert in eine Zeichenfolge umzuwandeln (funktioniert auch in der ORDER BY-Klausel), sodass Sie ein in verwenden können -Speicher temporäre Tabelle. Stellen Sie jedoch sicher, dass die abgefangene Teilzeichenfolge kurz genug ist, damit die Größe der temporären Tabelle max_heap_table_size oder tmp_table_size nicht überschreitet. Nach Überschreiten des Grenzwerts konvertiert MySQL die temporäre Speichertabelle in eine temporäre MyISAM-Festplattentabelle.
Die Längenzuordnung im ungünstigsten Fall ist auch für die Sortierung dieselbe, daher ist dieser Trick nützlich für die Erstellung großer temporärer Tabellen und die Dateisortierung im Speicher sowie für die Erstellung großer temporärer Tabellen auf Festplatte und Datei Sortierung ist in beiden Fällen hilfreich. Angenommen, Sie verfügen über eine Tabelle mit 10 Millionen Zeilen, die mehrere Gigabyte Speicherplatz beansprucht. Es gibt eine VARCHAR(1000)-Spalte mit dem Zeichensatz utf8. Jedes Zeichen belegt bis zu 3 Byte, was im schlimmsten Fall 3000 Byte Speicherplatz erfordert. Wenn diese Spalte in ORDER BY verwendet wird und die Abfrage die gesamte Tabelle durchsucht, werden mehr als 30 GB temporäre Tabellen zum Sortieren benötigt
· DATETIME/TIMESTAMP
MySQL enthält normalerweise zwei Zeitformate DATETIME und TIMESTAMP Der Unterschied zwischen den beiden Typen ist bei der Verwendung nicht sehr groß, aber es gibt immer noch Unterschiede im Detail
Da TMESSTAMP weniger Speicherplatz beansprucht, kann es verwendet werden. Es dient als das Standardzeitformat
· ENUM
Dieser Feldtyp speichert hauptsächlich Spaltenwerte durch Aufzählung, da er am Verwendungsprozess beteiligt ist. Die Konvertierung zwischen Die Position der Aufzählung und der tatsächliche Wert können einen gewissen Einfluss auf die Gesamtleistung haben, und der Aufzählungswert wird in .frm (Datentabellenstruktur-Definitionsdatei) gespeichert, also nach dem Erstellen der ENUM-Spalte, wenn Sie den Inhalt aktualisieren möchten EMUM entspricht der Aktualisierung der Tabellenstruktur.
Das Folgende ist ein einfaches Beispiel für die Erstellung einer ENUM-Spalte:
mysql> CREATE TABLEenum_test( -> e ENUM('fish', 'apple', 'dog') NOT NULL -> ); mysql> INSERT INTOenum_test(e) VALUES('fish'), ('dog'), ('apple');
In Versionen vor MySQL 5.0 galt BIT als gleichwertig mit TINYINT, in der neuen Version wird es jedoch als zwei völlig unterschiedliche Typen behandelt.
Wenn Sie ein BIT-Feld aus der Datenbank abrufen und auf der Konsole anzeigen, wird der Wert als ASCII-Kodierung angezeigt. Wenn der Wert des Feldes im Kontext einer Zahlenoperation erscheint, wird er behandelt as Der Dezimalwert von BIT kann diese beiden Situationen deutlich veranschaulichen.
mysql>CREATE TABLE bittest(a bit(8)); mysql> INSERT INTObittest VALUES(b'00111001'); mysql> SELECT a, a+ 0 FROM bittest; +------+-------+ | a | a + 0 | +------+-------+ | 9 | 57 | +------+-------+
Das Obige ist die Entwicklung von High- Leistung MySql (2): Inhalt unter Datentypoptimierung_. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

Die Position von MySQL in Datenbanken und Programmierung ist sehr wichtig. Es handelt sich um ein Open -Source -Verwaltungssystem für relationale Datenbankverwaltung, das in verschiedenen Anwendungsszenarien häufig verwendet wird. 1) MySQL bietet effiziente Datenspeicher-, Organisations- und Abruffunktionen und unterstützt Systeme für Web-, Mobil- und Unternehmensebene. 2) Es verwendet eine Client-Server-Architektur, unterstützt mehrere Speichermotoren und Indexoptimierung. 3) Zu den grundlegenden Verwendungen gehören das Erstellen von Tabellen und das Einfügen von Daten, und erweiterte Verwendungen beinhalten Multi-Table-Verknüpfungen und komplexe Abfragen. 4) Häufig gestellte Fragen wie SQL -Syntaxfehler und Leistungsprobleme können durch den Befehl erklären und langsam abfragen. 5) Die Leistungsoptimierungsmethoden umfassen die rationale Verwendung von Indizes, eine optimierte Abfrage und die Verwendung von Caches. Zu den Best Practices gehört die Verwendung von Transaktionen und vorbereiteten Staten

Apache verbindet eine Verbindung zu einer Datenbank erfordert die folgenden Schritte: Installieren Sie den Datenbanktreiber. Konfigurieren Sie die Datei web.xml, um einen Verbindungspool zu erstellen. Erstellen Sie eine JDBC -Datenquelle und geben Sie die Verbindungseinstellungen an. Verwenden Sie die JDBC -API, um über den Java -Code auf die Datenbank zuzugreifen, einschließlich Verbindungen, Erstellen von Anweisungen, Bindungsparametern, Ausführung von Abfragen oder Aktualisierungen und Verarbeitungsergebnissen.

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

Der Prozess des Startens von MySQL in Docker besteht aus den folgenden Schritten: Ziehen Sie das MySQL -Image zum Erstellen und Starten des Containers an, setzen

Die Hauptaufgabe von MySQL in Webanwendungen besteht darin, Daten zu speichern und zu verwalten. 1.Mysql verarbeitet effizient Benutzerinformationen, Produktkataloge, Transaktionsunterlagen und andere Daten. 2. Durch die SQL -Abfrage können Entwickler Informationen aus der Datenbank extrahieren, um dynamische Inhalte zu generieren. 3.Mysql arbeitet basierend auf dem Client-Server-Modell, um eine akzeptable Abfragegeschwindigkeit sicherzustellen.

Laravel ist ein PHP -Framework zum einfachen Aufbau von Webanwendungen. Es bietet eine Reihe leistungsstarker Funktionen, darunter: Installation: Installieren Sie die Laravel CLI weltweit mit Komponisten und erstellen Sie Anwendungen im Projektverzeichnis. Routing: Definieren Sie die Beziehung zwischen der URL und dem Handler in Routen/Web.php. Ansicht: Erstellen Sie eine Ansicht in Ressourcen/Ansichten, um die Benutzeroberfläche der Anwendung zu rendern. Datenbankintegration: Bietet eine Out-of-the-Box-Integration in Datenbanken wie MySQL und verwendet Migration, um Tabellen zu erstellen und zu ändern. Modell und Controller: Das Modell repräsentiert die Datenbankentität und die Controller -Prozesse HTTP -Anforderungen.

Der Schlüssel zur eleganten Installation von MySQL liegt darin, das offizielle MySQL -Repository hinzuzufügen. Die spezifischen Schritte sind wie folgt: Laden Sie den offiziellen GPG -Schlüssel von MySQL herunter, um Phishing -Angriffe zu verhindern. Add MySQL repository file: rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm Update yum repository cache: yum update installation MySQL: yum install mysql-server startup MySQL service: systemctl start mysqld set up booting
