Механизмы сохранения данных онлайн урок.


В MySQL существуют несколько типов движков для разных механизмов сохранения данных. Для того, чтобы просмотреть доступные движки, необходимо исполнить запрос SHOW ENGINES

+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine | Support | Comment | Transactions | XA | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL |
| MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO |
| MyISAM | YES | MyISAM storage engine | NO | NO | NO |
| BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO |
| CSV | YES | CSV storage engine | NO | NO | NO |
| MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO |
| ARCHIVE | YES | Archive storage engine | NO | NO | NO |
| InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES |
| PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+

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

Также распространенным движком является MyISAM, но в нем нету поддержки внешних ключей.

В наших уроках мы будем использовать движок InnoDB.

Для того, чтобы задать движок при создании таблицы необходимо использовать оператор ENGINE:

CREATE TABLE ( ... ) ENGINE = InnoDB