Jump to content

МойИСАМ

МойИСАМ
Разработчик(и) Корпорация Oracle
Написано в С
Операционная система Кросс-платформенный
Тип Механизм базы данных
Лицензия Стандартная общественная лицензия GNU
Веб-сайт разработчик .mysql /док /refman /8 .0 /myisam-storage-engine .html

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

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

[ редактировать ]

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

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

  • 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 :: 13 механизмов хранения :: 13.6 Механизм хранения InnoDB» . 10 мая 2009 г. Архивировано из оригинала 20 ноября 2010 г. Проверено 16 марта 2021 г.
  2. ^ «Производительность MySQL: InnoDB против MyISAM в версии 5.6» . 16 ноября 2012 г. Проверено 16 марта 2021 г.
  3. ^ «Ария FAQ» . МарияДБ . 15 августа 2010 г. Проверено 16 марта 2021 г.
  4. ^ «Сегментированный кэш ключей» . МарияДБ . 17 августа 2010 г. Проверено 16 марта 2021 г.
[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: b086c74043a6f5165a977f6aa1b8b257__1701724800
URL1:https://arc.ask3.ru/arc/aa/b0/57/b086c74043a6f5165a977f6aa1b8b257.html
Заголовок, (Title) документа по адресу, URL1:
MyISAM - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)