MySQL: руководство профессионала
Шрифт:
PARTITION p1 VALUES LESS THAN (2000) (
SUBPARTITION s1a DATA DIRECTORY = '/disk4/data'
INDEX DIRECTORY = '/disk4/idx',
SUBPARTITION s1b DATA DIRECTORY = '/disk5/data'
INDEX DIRECTORY = '/disk5/idx'),
PARTITION p2 VALUES LESS THAN MAXVALUE (
SUBPARTITION s2a, SUBPARTITION s2b));
Здесь хранение следующее:
Строки с датами purchased до 1990 занимают обширное количество места, поэтому поделены 4 путями: с отдельным диском, специализированным
Данные для подраздела s0a сохранены на /disk0.
Индексы для подраздела s0a сохранены на /disk1.
Данные для подраздела s0b сохранены на /disk2.
Индексы для подраздела s0b сохранены на /disk3.
Строки, содержащие даты в пределах от 1990 до 1999 (раздел p1) не требуют так много памяти, как даты до 1990. Они размазаны между 2 дисками (/disk4 и /disk5):
Данные и индексы, принадлежащие первому подразделу (s1a) раздела p1, сохранены на /disk4: данные в /disk4/data, а индексы в /disk4/idx.
Данные и индексы, принадлежащие второму подразделу (s1b) раздела p1, сохранены на /disk5: данные в /disk5/data, а индексы в /disk5/idx.
Строки, отражающие даты с года 2000 до текущей (раздел p2), не занимают так много места, как любой из двух предыдущих диапазонов. В настоящее время достаточно сохранить всех их в заданном по умолчанию расположении.
В будущем, когда число purchases в течение десятилетия, начинающегося годом 2000, вырастет до отметки, где заданное по умолчанию расположение больше не обеспечивает достаточного места, соответствующие строки могут перемещаться, используя ALTER TABLE … REORGANIZE PARTITION.
3.2.6. Как выделитель разделов в MySQL обрабатывает значения NULL
Выделение разделов в MySQL не делает ничего, чтобы отвергнуть NULL как значение выражения выделения разделов независимо от того, является ли это значением столбца или обеспеченного пользователем выражения. Даже разрешается использовать NULL как значение выражения, которое должно выдать целое число, но важно иметь в виду, что NULL числом не является. Начиная с версии 5.1.8, MySQL обрабатывает NULL как будто он меньше, чем любое не нулевое значение, точно как делает ORDER BY.
Из-за этого эта обработка NULL изменяется при выделении разделов различных типов, и может производить поведение, которое Вы не ожидаете. Если Вы вставляете строку в таблицу, разбитую на разделы RANGE так, что значение столбца, используемое, чтобы определить раздел, является NULL, строка вставлена в самый нижний раздел. Например, рассмотрите эти две таблицы, созданные и заполняемые следующим образом:
mysql> CREATE TABLE t1 (c1 INT, c2 VARCHAR(20))
– > PARTITION BY RANGE(c1) (
– > PARTITION p0 VALUES LESS THAN (0),
– > PARTITION p1 VALUES LESS THAN (10),
– > PARTITION p2 VALUES LESS THAN MAXVALUE);
Query OK, 0 rows affected (0.09 sec)
mysql> CREATE TABLE t1 (c1 INT, c2 VARCHAR(20))
– > PARTITION BY RANGE(c1) (
– > PARTITION p0 VALUES LESS THAN (-5),
– > PARTITION p1 VALUES LESS THAN (0),
– > PARTITION p1 VALUES LESS THAN (10),
– > PARTITION p2 VALUES LESS THAN MAXVALUE);
Query OK, 0 rows affected (0.09 sec)
mysql> INSERT INTO t1 VALUES (NULL, 'mothra');
Query OK, 1 row affected (0.00 sec)
mysql> INSERT INTO t2 VALUES (NULL, 'mothra');
Query OK, 1 row affected (0.00 sec)
mysql> SELECT * FROM t1;
+------+--------+
| id | name |
+------+--------+
| NULL | mothra |
+------+--------+
1 row in set (0.00 sec)
mysql> SELECT * FROM t2;
+------+--------+
| id | name |
+------+--------+
| NULL | mothra |
+------+--------+
1 row in set (0.00 sec)
Вы
/var/lib/mysql/test> ls -l *.MYD
– rw-rw---- 1 mysql mysql 20 2006-03-10 03:27 t1#P#p0.MYD
– rw-rw---- 1 mysql mysql 0 2006-03-10 03:17 t1#P#p1.MYD
– rw-rw---- 1 mysql mysql 0 2006-03-10 03:17 t1#P#p2.MYD
– rw-rw---- 1 mysql mysql 20 2006-03-10 03:27 t2#P#p0.MYD
– rw-rw---- 1 mysql mysql 0 2006-03-10 03:17 t2#P#p1.MYD
– rw-rw---- 1 mysql mysql 0 2006-03-10 03:17 t2#P#p2.MYD
– rw-rw---- 1 mysql mysql 0 2006-03-10 03:17 t2#P#p3.MYD
Файлы разделов именованы согласно формату table_name#P#partition_name .extension так, чтобы t1#P#p0.MYD был файлом, в котором сохранены данные, принадлежащие к разделу p0 таблицы t1. Обратите внимание: до MySQL 5.1.5, эти файлы были бы именованы соответственно t1_p0.MYD и t2_p0.MYD.
Вы можете также показывать, что эти строки были сохранены в самом низком разделе каждой таблицы, удаляя эти разделы, а затем делая повторный запуск инструкций SELECT:
mysql> ALTER TABLE t1 DROP PARTITION p0;
Query OK, 0 rows affected (0.16 sec)
mysql> ALTER TABLE t2 DROP PARTITION p0;
Query OK, 0 rows affected (0.16 sec)
mysql> SELECT * FROM t1;
Empty set (0.00 sec)
mysql> SELECT * FROM t2;
Empty set (0.00 sec)