Dieser Artikel führt hauptsächlich eine kurze Analyse der MySQL-Datentabellenpartitionierungstechnologie PARTITION ein und stellt die Partitionierungstechnologien RANGE, LIST und HASH in MySQL vor. Freunde in Not können sich darauf beziehen.
In diesem Kapitel lernen wir die Partitionierungstechnologie (RANGE, LIST, HASH) in MySQL kennen
Die Partitionierungstechnologie von MySQL ähnelt in gewisser Weise der horizontalen Tabellenpartitionierung, wird jedoch durchgeführt Die logische Ebene ist immer noch eine Tabelle für die Anwendung. Mit anderen Worten: Durch die Partitionierung wird eine Tabelle nicht geteilt.
RANGE-Partitionierung: Weisen Sie Partitionen mehrere Zeilen zu, basierend auf Spaltenwerten, die zu einem bestimmten kontinuierlichen Bereich gehören
LIST-Partitionierung: Ähnlich wie die Partitionierung nach RANGE besteht der Unterschied darin, dass die LIST-Partitionierung darauf basiert, dass der Spaltenwert mit einem bestimmten Wert in einem diskreten Wertesatz zur Auswahl übereinstimmt.
HASH-Partitionierung: basierend auf dem Rückgabewert eines Benutzer- definierter Ausdruck Um Partitionen auszuwählen, wird dieser Ausdruck anhand der Spaltenwerte der in die Tabelle einzufügenden Zeilen berechnet. Diese Funktion kann jeden in MySQL gültigen Ausdruck enthalten, der einen nicht negativen ganzzahligen Wert
KEY erzeugt Partitionierung: Im Vergleich zur Partitionierung durch HASH besteht der Unterschied darin, dass die KEY-Partition nur die Berechnung einer oder mehrerer Spalten unterstützt und der MySQL-Server eine eigene Hash-Funktion bereitstellt
1. Definieren Sie bei der Partitionierung entweder nicht den Primärschlüssel oder fügen Sie das Partitionsfeld zum Primärschlüssel hinzu
2. Das Partitionsfeld darf nicht NULL sein, sonst wird der Partitionsbereich bestimmt. Versuchen Sie also, NOT NULL
zu verwenden. Zuerst können Sie überprüfen, ob Ihre MySQL-Version PARTITION
mysql> show plugins; | partition | ACTIVE | STORAGE ENGINE | NULL | GPL |
oder
mysql> show variables like "%part%"; +-------------------+-------+ | Variable_name | Value | +-------------------+-------+ | have_partitioning | YES | +-------------------+-------+
Angenommen, Sie erstellen eine Tabelle wie folgt: Diese Tabelle enthält Mitarbeiterdatensätze von 20 Videotheken und die 20 Videotheken sind von 1 bis 20 nummeriert. Wenn Sie es in 4 kleine Partitionen aufteilen möchten, können Sie die RANGE-Partition verwenden. Die erstellte Datenbanktabelle sieht wie folgt aus:
mysql-> CREATE TABLE employees ( -> id INT NOT NULL, -> fname VARCHAR(30), -> lname VARCHAR(30), -> hired DATE NOT NULL DEFAULT '1970-01-01', -> separated DATE NOT NULL DEFAULT '9999-12-31', -> job_code INT NOT NULL, -> store_id INT NOT NULL -> ) ENGINE=Myisam DEFAULT CHARSET=utf8 -> PARTITION BY RANGE (store_id) ( -> PARTITION P0 VALUES LESS THAN (6), -> PARTITION P1 VALUES LESS THAN (11), -> PARTITION P2 VALUES LESS THAN (16), -> PARTITION P3 VALUES LESS THAN (21) -> );
Wenn Sie Mitarbeiter, die in verschiedenen Zeiträumen gekündigt haben, separat speichern möchten, dann sind Sie hier richtig Kann Das getrennte Datumsfeld (d. h. der Zeitpunkt des Rücktritts) wird als Schlüssel verwendet und die erstellte SQL-Anweisung lautet wie folgt:
mysql-> CREATE TABLE employees ( -> id INT NOT NULL, -> fname VARCHAR(30), -> lname VARCHAR(30), -> hired DATE NOT NULL DEFAULT '1970-01-01', -> separated DATE NOT NULL DEFAULT '9999-12-31', -> job_code INT NOT NULL, -> store_id INT NOT NULL -> ) ENGINE=Myisam DEFAULT CHARSET=utf8 -> PARTITION BY RANGE (YEAR(separated)) ( -> PARTITION P0 VALUES LESS THAN (2001), -> PARTITION P1 VALUES LESS THAN (2011), -> PARTITION P2 VALUES LESS THAN (2021), -> PARTITION P3 VALUES LESS THAN MAXVALUE -> );
Gleiches Beispiel, wenn diese 20 Videotheken in 4 Regionen mit Vertriebsrechten verteilt sind
+------------------+--------------------------------------+ | 地区 | 音像店 ID 号 | +------------------+--------------------------------------+ | 北区 | 3, 5, 6, 9, 17 | | 东区 | 1, 2, 10, 11, 19, 20 | | 西区 | 4, 12, 13, 14, 18 | | 中心区 | 7, 8, 15, 16 | +------------------+--------------------------------------+ mysql-> CREATE TABLE employees ( -> id INT NOT NULL, -> fname VARCHAR(30), -> lname VARCHAR(30), -> hired DATE NOT NULL DEFAULT '1970-01-01', -> separated DATE NOT NULL DEFAULT '9999-12-31', -> job_code INT NOT NULL, -> store_id INT NOT NULL -> ) ENGINE=Myisam DEFAULT CHARSET=utf8 -> PARTITION BY LIST (store_id) ( -> PARTITION pNorth VALUES IN (3, 5, 6, 9, 17), -> PARTITION pEast VALUES IN (1, 2, 10, 11, 19, 20), -> PARTITION pWest VALUES IN (4, 12, 13, 14, 18), -> PARTITION pCentral VALUES IN (7, 8, 15, 16) -> );
Nachdem Sie es erstellt haben, können Sie die MySQL-Datenspeicherdatei eingeben in der MySQL-Konfigurationsdatei
shawn@Shawn:~$ sudo vi /etc/mysql/my.cnf; [mysqld] datadir = /var/lib/mysql shawn@Shawn:~$ cd /var/lib/mysql/dbName shawn@Shawn:/var/lib/mysql/dbName$ ll 显示如下: 8768 Jun 7 22:01 employees.frm 48 Jun 7 22:01 employees.par 0 Jun 7 22:01 employees#P#pCentral.MYD 1024 Jun 7 22:01 employees#P#pCentral.MYI 0 Jun 7 22:01 employees#P#pEast.MYD 1024 Jun 7 22:01 employees#P#pEast.MYI 0 Jun 7 22:01 employees#P#pNorth.MYD 1024 Jun 7 22:01 employees#P#pNorth.MYI 0 Jun 7 22:01 employees#P#pWest.MYD 1024 Jun 7 22:01 employees#P#pWest.MYI
Wie Sie hier sehen können, werden die Speicherdateien gemäß unserer Definition aufgeteilt
employees.frm = 表结构 employees.par = partition, 申明是一个分区表 .MYD = 数据文件 .MYI = 索引文件
HASH-Partitionierung wird hauptsächlich verwendet, um sicherzustellen, dass Daten gleichmäßig auf eine vorgegebene Anzahl von Partitionen verteilt werden.
Wenn Sie Mitarbeiter, die in verschiedenen Zeiträumen beigetreten sind, separat speichern möchten, können Sie das Datumsfeld mieten als Schlüssel
mysql-> CREATE TABLE employees ( -> id INT NOT NULL, -> fname VARCHAR(30), -> lname VARCHAR(30), -> hired DATE NOT NULL DEFAULT '1970-01-01', -> separated DATE NOT NULL DEFAULT '9999-12-31', -> job_code INT NOT NULL, -> store_id INT NOT NULL -> ) ENGINE=Myisam DEFAULT CHARSET=utf8 -> PARTITION BY HASH (YEAR(hired)) ( -> PARTITIONS 4 -> ); #这里注意的是 PARTITIONS, 多了一个 s
Was hier erwähnt werden sollte, ist, dass die obigen Beispiele alle die Myisam-Speicher-Engine verwenden, die standardmäßig unabhängige Tabellenbereiche verwendet, sodass Sie unterschiedliche Werte in sehen können Festplattenspeicher oben. Partitionieren
Die InnoDB-Engine verwendet standardmäßig einen gemeinsam genutzten Tabellenbereich. Sie werden feststellen, dass sie nicht wie Myisam physisch partitioniert ist, sodass Sie die MySQL-Konfiguration ändern müssen 🎜>
shawn@Shawn:~$ sudo vi /etc/mysql/my.cnf; #添加: innodb_file_per_table=1 #重启 mysql shawn@Shawn:~$ sudo /etc/init.d/mysql restart
8768 Jun 7 22:54 employees.frm 48 Jun 7 22:54 employees.par 98304 Jun 7 22:54 employees#P#pCentral.ibd 98304 Jun 7 22:54 employees#P#pEast.ibd 98304 Jun 7 22:54 employees#P#pNorth.ibd 98304 Jun 7 22:54 employees#P#pWest.ibd
mysql> alter table employees drop partition pWest;
Das obige ist der detaillierte Inhalt vonEine kurze Analyse von Codebeispielen der MySQL-Datentabellenpartitionierungstechnologie PARTITION. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!