Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment supprimer toutes les tables MySQL de la ligne de commande sans autorisations de base de données DROP ?

Vous pouvez générer une instruction comme celle-ci :DROP TABLE t1, t2, t3, ... puis utilisez des instructions préparées pour l'exécuter :

SET FOREIGN_KEY_CHECKS = 0; 
SET @tables = NULL;
SELECT GROUP_CONCAT('`', table_schema, '`.`', table_name, '`') INTO @tables
  FROM information_schema.tables 
  WHERE table_schema = 'database_name'; -- specify DB name here.

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