sql >> Databáze >  >> RDS >> Mysql

Jak převést všechny tabulky z MyISAM do InnoDB?

Spuštěním tohoto příkazu SQL (v klientovi MySQL, phpMyAdmin nebo kdekoli jinde) získáte všechny tabulky MyISAM ve své databázi.

Nahraďte hodnotu name_of_your_db proměnná s názvem vaší databáze.

SET @DATABASE_NAME = 'name_of_your_db';

SELECT  CONCAT('ALTER TABLE `', table_name, '` ENGINE=InnoDB;') AS sql_statements
FROM    information_schema.tables AS tb
WHERE   table_schema = @DATABASE_NAME
AND     `ENGINE` = 'MyISAM'
AND     `TABLE_TYPE` = 'BASE TABLE'
ORDER BY table_name DESC;

Potom zkopírujte výstup a spusťte jej jako nový dotaz SQL.



  1. Časová pásma MySQL

  2. DevOps:DBA nebo vývojář – Jak dosáhnout správné rovnováhy

  3. Jaký je význam otazníku v MySQL ve sloupci WHERE =??

  4. Jak formátovat čísla jako měnu v MySQL