2.8.1.3. Конвертація сховища всіх таблиць

Вимоги: PHP 5+

Для конвертації всіх таблиць можна запустити скрипт, який виконає SQL-запит для кожної окремої таблиці.

  1. <?php
  2. $DB = array(
  3. 'host' => 'example.mysql.tools',
  4. 'user' => 'example_db',
  5. 'password' => 'xxxxxxxxxx',
  6. 'database' => 'example_db',
  7. 'engine' => 'InnoDB'
  8. );
  9. $link = mysqli_connect($DB['host'], $DB['user'], $DB['password'], $DB['database']);
  10. $sql = "SHOW TABLES";
  11. $query = mysqli_query($link, $sql);
  12. while ($row = mysqli_fetch_assoc($query)) {
  13. if (mysqli_query($link, "ALTER TABLE `".$row['Tables_in_'.$DB['database']]."` ENGINE = ".$DB['engine'])) {
  14. echo $row['Tables_in_'.$DB['database']]." ok<br>";
  15. } else {
  16. echo $row['Tables_in_'.$DB['database']]." error<br>";
  17. }
  18. }

В скрипті потрібно вказати дані для підключення до бази даних:

  1. host — сервер баз даних.
  2. user — ім'я користувача бази даних.
  3. password — пароль користувача баз даних.
  4. database — назва бази даних.
  5. engine — цільової тип сховища на який будуть змінені всі таблиці.

Альтернативні способи зміни типу сховища описані тут.

Зміст