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

Увага!

Не рекомендується використовувати цей спосіб для великих баз даних.

Для зміни типу сховища всіх таблиць бази даних можна запустити скрипт, який виконає необхідний 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. }

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

  • host — сервер баз даних.
  • user — ім’я користувача бази даних.
  • password — пароль користувача бази даних.
  • database — назва бази даних.
  • engine — тип сховища, який потрібно встановити.
Зміст