Mysqlの全テーブル一括削除コマンド

  • 作成日 2019.08.16
  • 更新日 2022.10.22
  • mysql
Mysqlの全テーブル一括削除コマンド

あんまりやることないけど、サーバー移行案件で必要だったのでメモ

SET FOREIGN_KEY_CHECKS = 0;
SET GROUP_CONCAT_MAX_LEN=32768;
SET @tables = NULL;
SELECT GROUP_CONCAT('`', table_name, '`') INTO @tables
  FROM information_schema.tables
  WHERE table_schema = (SELECT DATABASE());
SELECT IFNULL(@tables,'dummy') INTO @tables;

SET @tables = CONCAT('DROP TABLE IF EXISTS ', @tables);
PREPARE stmt FROM @tables;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET FOREIGN_KEY_CHECKS = 1;

これで一括で削除できました