МойISAM

Движок базы данных
МойISAM
Разработчик(и)Корпорация Оракул
Написано вС
Операционная системаКроссплатформенный
ТипДвижок базы данных
ЛицензияСтандартная общественная лицензия GNU
Веб-сайтdev.mysql.com/doc/refman/8.0/en/myisam-storage-engine.html

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

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

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

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

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

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

Функции

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

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

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

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

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

Вилки

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

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

Drizzle не включает MyISAM.

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

Примечания

  1. ^ "MySQL 5.5 Reference Manual :: 13 Storage Engines :: 13.6 The InnoDB Storage Engine". 2009-05-10. Архивировано из оригинала 2010-11-20 . Получено 16-03-2021 .
  2. ^ "Производительность MySQL: InnoDB против MyISAM в 5.6". 2012-11-16 . Получено 2021-03-16 .
  3. ^ "Aria FAQ". MariaDB . 2010-08-15 . Получено 2021-03-16 .
  4. ^ "Сегментированный ключевой кэш". MariaDB . 2010-08-17 . Получено 2021-03-16 .
  • Документация MySQL по движку хранения MyISAM
  • Объяснение лимита открытых файлов MyISAM и проблемы кэширования таблиц
  • Статья о проблемах, которые могут возникнуть при использовании MyISAM
  • MySQL Engines - MyISAM против Innodb от Rackspace (Архивировано 2015-02-08)
  • Преобразуйте свою базу данных MySQL из MyISAM в InnoDB и одновременно подготовьтесь к Drupal 7 (Архивировано 08.03.2013)
  • Преобразование таблиц из MyISAM в InnoDB
Взято с "https://en.wikipedia.org/w/index.php?title=MyISAM&oldid=1188371537"