MyISAM - MyISAM

MyISAM
Разработчики)Корпорация Oracle
Написано вC
Операционная системаКроссплатформенность
ТипЯдро базы данных
ЛицензияСтандартная общественная лицензия GNU
Интернет сайтwww.mysql.com

MyISAM был по умолчанию механизм хранения для MySQL система управления реляционной базой данных версии до 5.5, выпущенные в декабре 2009 г.[1] Он основан на более старом ISAM код, но у него много полезных расширений.

Файловая система

Каждая таблица MyISAM хранится на диске в трех файлах (если он не разбит на разделы). Файлы имеют имена, которые начинаются с имени таблицы и имеют расширение, указывающее тип файла. MySQL использует файл .frm для хранения определения таблицы, но этот файл не является частью механизма MyISAM; вместо этого это часть сервера. Файл данных имеет расширение .MYD (MYData). Индексный файл имеет расширение .MYI (MYIndex). Индексный файл, если он потерян, всегда можно воссоздать заново, воссоздав индексы.

Формат файлов зависит от параметра таблицы ROW_FORMAT. Доступны следующие форматы:

  • ИСПРАВЛЕНО: Fixed - это формат, в котором все данные (включая типы переменной длины) имеют фиксированную длину. Этот формат быстрее читается и улучшает восстановление поврежденных таблиц. Если таблица содержит большие столбцы переменной длины (BLOB или TEXT), она не может использовать ФИКСИРОВАННЫЙ формат.
  • ДИНАМИЧНЫЙ: столбцы переменной длины не имеют фиксированного размера. Этот формат немного медленнее для чтения, но экономит место на диске.
  • СЖАТЫЕ: сжатые таблицы могут быть созданы с помощью специального инструмента, пока MySQL не запущен, и они доступны только для чтения. Хотя это обычно делает их нежизнеспособным вариантом, степень сжатия обычно значительно выше, чем у альтернатив.

Файлы MyISAM не зависят от системы, и, поскольку MyISAM не является транзакционным, их содержимое не зависит от текущей рабочей нагрузки сервера. Поэтому их можно копировать между разными серверами.

Функции

MyISAM оптимизирован для сред с интенсивными операциями чтения и небольшим количеством операций записи или вообще без них. Типичная область, в которой можно предпочесть MyISAM, - это хранилище данных потому что он включает запросы к очень большим таблицам, и обновление таких таблиц выполняется, когда база данных не используется (обычно ночью).

Причина, по которой MyISAM допускает быстрое чтение, - это структура его индексов: каждая точка входа указывает на запись в файле данных, а указатель смещен от начала файла. Таким образом, записи могут быть быстро прочитаны, особенно если формат ФИКСИРОВАН. Таким образом, строки имеют постоянную длину. Вставки тоже просты, потому что новые строки добавляются в конец файла данных. Однако операции удаления и обновления более проблематичны: при удалении должно оставаться пустое место, иначе смещения строк могут измениться; то же самое касается обновлений, так как длина строк становится короче; если при обновлении строка становится длиннее, строка фрагментируется. Чтобы дефрагментировать строки и потребовать пустое пространство, необходимо выполнить команду OPTIMIZE TABLE. Благодаря этому простому механизму статистика индекса MyISAM обычно довольно точна.

Однако простота MyISAM имеет несколько недостатков. Основным недостатком MyISAM является отсутствие сделки поддерживать. Также, внешние ключи не поддерживаются. В обычных случаях InnoDB кажется быстрее MyISAM.[2]

Версии MySQL 5.5 и выше перешли на InnoDB двигатель для обеспечения ссылочная целостность ограничения и выше параллелизм.

MyISAM поддерживает индексирование FULLTEXT и типы данных OpenGIS.

Вилки

MariaDB имеет механизм хранения, называемый Ария, который описывается как «безопасная альтернатива MyISAM».[3] Однако разработчики MariaDB все еще работают над кодом MyISAM. Основное улучшение - это «Сегментированный ключевой кэш».[4] Если он включен, кеш индексов MyISAM делится на сегменты. Это улучшает параллелизм, поскольку потокам редко требуется блокировать весь кеш.

В MariaDB MyISAM также поддерживает виртуальные столбцы.

Морось не включает MyISAM.

Смотрите также

Примечания

внешняя ссылка