موتور ذخیرهسازی Memory:
در این نوع همانطور که از اسم آن نیز پیدا است کلیه دادهها در Memory (حافظه RAM) ذخیره میشود و با خاموش شدن سیستم دادههای جدولی که با این نوع طراحی شدهاست از بین خواهد رفت.
در مواردی که به سرعت بالا نیاز است و یا دادهها بصورت مداوم در حال نوشتن و خواندن هستند (مثل جداول temprory) استفاده از آن بهینه است.
موتور ذخیرهسازی CSV:
در CSV دادهها بهصورت باینری ذخیره نمیشوند و ذخیره دادهها در یک فایل csv انجام میگیرد. بهدلیل این محدودیت، برای ذخیره تعداد زیادی داده یا انواع دادههای بزرگ مناسب نیست.
فایلهای CSV بدلیل سادگی import و Export شدن به نرم افزارهایی مانند Excel ،OpenOffice ،Access و FileMaker تولید میشوند.
موتور ذخیرهسازی Archive:
در Archive اغلب انواع داده MySQL پشتیبانی میشود اما تنها دستورات Select و Insert قابل استفاده است. اطلاعات جدولی از این نوع بهصورت فشرده ذخیره میشود و غیر قابل ویرایش میباشد، بنابراین برای ذخیره log فایلها (یا اطلاعاتی مانند صورت حسابهای گذشته) و اطلاعات امنیتی مناسب میباشد.
با توجه به اینکه Select از جدولهایی ذخیره شده با این نوع نیاز به خارجسازی اطلاعات از حالت فشرده وجود دارد، در جستجوها و روابط پیچیده این موضوع زمانبر خواهد بود.
موتور ذخیرهسازی Federated:
Federated در نسخه MySQL ۵٫۰۳ اضافه و در آن امکان اتصال به سایر دیتابیسها فراهم شدهاست، به عبارتی چند سرور MySQL که ازنظر فیزیکی جدا هستند، به هم متصل میشوند و یک پایگاه داده مجازی را تشکیل دهند. با استفاده از Federated میتوان به یک دیتابیس دیگر متصل شد و دادههای جدولها را بدون Export یا Import نمودن به دیتابیس دیگر منتقل نمود.
موتور ذخیرهسازی BLACKHOLE:
BLACKHOLE دادهها را دریافت میکند اما ذخیره نمیکند و مانند /dev/null در یونیکس است. در طراحی دیتابیسهای توزیع شده که بطور خودکار دادهها تکرار شده اما بصورت لوکال ذخیره نمی شوند بهینه میباشد. بدون اینکه دادهها بصورت واقعی نوشته شوند امکان اجرای دستورات select و update وجود دارد.
اگرچه بنظر میرسد که روش بیهودهای است اما این روش جهت تست ساختار دیتابیس و کار با جدولهای تعریف شده مفید میباشد.
موتور ذخیرهسازی Merge:
با استفاده از Merge میتوان مجموعهای از جداول MyISAM یکسان را بطور منطقی دسته بندی کرده و بعنوان یک شی واحد درنظر بگیرد. با استفاده از این نوع موتور ذخیره سازی مدیریت مجموعهای از جداول لاگ به آسانی انجام میشود و جستجوهای کارآمدتری را میتوانید انجام دهید.
موتور ذخیرهسازی InnoDB:
از نسخه ۵٫۵٫۵ به بعد، InnoDB موتور ذخیره سازی پیش فرض MySQL شد و این موتور ذخیره سازی نسبت به MyISAM از پیچیدگی بیشتری برخوردار میباشد.
یکی از ویژگیهای آن پشتیبانی از transactionها میباشد. همچنین InnoDB از کلید خارجی جهت محدودیت روابط بین جداول پشتیبانی میکند که این موضوع حفظ روابط بین جداول یکی از دلایل پیچیدهتر بودن آن نسبت به MyISAM میباشد.
InnoDB از قابلیت crash-recovery پشتیبانی میکند و در صورت آسیب دیدن جدول به بازیابی آن کمک میکند. بههمین دلیل در مواردی که اطلاعات مهم و حساس باشند استفاده از این موتور ذخیره سازی بهینهتر است.
InnoDB حافظه بیشتری را نسب به MyISAM مصرف میکند و از نظر فیزیکی فایلهای حجیمتری دارد، بنابر این اگر محدودیت در منابع وجود داشته باشد استفاده از InnoDB بهینه نیست.
این موتور ذخیره سازی دارای قابلیت lock (قفل کردن) در سطح رکورد و عدم قفل شدن کل جدول در عملیات ثبت و ویرایش ردیفها میباشد؛ به همین دلیل در سطح رکورد از سرعت بالایی جهت اجرای queryهای مربوط به insert/update/delete برخوردار میباشد.
موتور ذخیرهسازی MyISAM:
یکی از ویژگیهای مفید MyISAM پشتیبانی از full-text search می باشد و جدولهایی که از این موتور ذخیره سازی استفاده میکنند فضای کمتری از دیسک را اشغال میکنند.
MyISAM نسبت به سایر موتورهای ذخیرهسازی از سادگی بشتری برخوردار و برای افراد مبتدی مناسبتر است.
MyISAM بهدلیل locking در سطح جدول سرعت پائینی در queryهای insert/update دارد، اما سرعت آن در select بالا است.
جدولها در MyISAM میتوانند بهصورت فقط خواندنی (جهت کاهش فضا) ذخیره شوند. بنابراین درمواردی که سادگی و محدودیت منابع اولویت داشته باشد استفاده از این موتور ذخیرهسازی بهینه میباشد.