7.3 Таблицы ISAM | Оглавление | 7.5 Таблицы InnoDB |
Для HEAP
-таблиц используются хэш-индексы; эти таблицы хранятся в памяти. Благодаря этому обработка их осуществляется очень быстро, однако в случае сбоя MySQL будут утрачены все данные, которые в них хранились. Тип HEAP
очень хорошо подходит для временных таблиц!
Для внутренних HEAP
-таблиц в MySQL используется 100%-ное динамическое хэширование без областей переполнения; дополнительное пространство для свободных списков не требуется. Отсутствуют при использовании HEAP
-таблиц и проблемы с командами удаления и вставки, которые часто применяются в хэшированных таблицах:
mysql> CREATE TABLE test TYPE=HEAP SELECT ip,SUM(downloads) AS down -> FROM log_table GROUP BY ip; mysql> SELECT COUNT(ip),AVG(down) FROM test; mysql> DROP TABLE test;
При использовании HEAP
-таблиц необходимо обращать внимание на следующие моменты:
MAX_ROWS
в операторе CREATE
, чтобы случайным образом не занять всю память.=
и <=>
(но ОЧЕНЬ быстрые).HEAP
-таблицах для поиска строки могут использоваться только полные ключи, в то время как для таблиц MyISAM
при поиске строк может применяться любой префикс ключа.HEAP
-таблиц используется формат с фиксированной длиной записи.HEAP
-таблиц не поддерживаются столбцы формата BLOB
/TEXT
.HEAP
-таблиц не поддерживаются столбцы формата AUTO_INCREMENT
.HEAP
-таблиц не поддерживаются индексы в столбцах формата NULL
.HEAP
-таблицах могут встречаться совпадающие ключи (что не является нормой для хэшированных таблиц).HEAP
-таблицы используются совместно всеми клиентами (как и все другие таблицы).ORDER BY
).HEAP
-таблиц расположены в маленьких блоках. Таблицы на 100% являются динамическими (при вставке). Нет необходимости ни в областях переполнения, ни в дополнительных ключах. Удаленные строки помещаются в связанный список и используются при вставке в таблицу новых данных.HEAP
-таблиц, которые будут использоваться одновременно,.DELETE FROM heap_table
, TRUNCATE heap_table
или DROP TABLE heap_table
.MyISAM
в формат HEAP
.HEAP
не может превышать max_heap_table_size
; это сделано для того, чтобы обеспечить защиту от случайных неквалифицированных действий.Количество памяти, необходимой для одной строки в HEAP
-таблице, вычисляется следующим образом:
SUM_OVER_ALL_KEYS(max_length_of_key + sizeof(char*) * 2) + ALIGN(length_of_row+1, sizeof(char*))
sizeof(char*)
составляет 4 на 32-разрядных компьютерах и 8 - на 64-разрядных.
7.3 Таблицы ISAM | Оглавление | 7.5 Таблицы InnoDB |