Для 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.
До версии 4.0.2 для HEAP-таблиц не поддерживаются индексы в столбцах формата NULL.
В HEAP-таблицах могут встречаться совпадающие ключи (что не является нормой для хэшированных таблиц).
HEAP-таблицы используются совместно всеми клиентами (как и все другие таблицы).
Нельзя производить поиск следующей записи в порядке следования (т.е. использовать индекс в команде ORDER BY).
Данные HEAP-таблиц расположены в маленьких блоках. Таблицы на 100% являются динамическими (при вставке). Нет необходимости ни в областях переполнения, ни в дополнительных ключах. Удаленные строки помещаются в связанный список и используются при вставке в таблицу новых данных.