如何使用命令提示符删除Windows MySQL中的所有表?我想这样做的原因是,我们的用户有权删除数据库,但无权重新创建数据库本身,因此我们必须手动删除表.有没有办法一次放下所有的桌子?请记住,大多数表都与外键链接,因此必须按特定顺序删除它们.
如何使用命令提示符删除Windows MySQL中的所有表?我想这样做的原因是,我们的用户有权删除数据库,但无权重新创建数据库本身,因此我们必须手动删除表.有没有办法一次放下所有的桌子?请记住,大多数表都与外键链接,因此必须按特定顺序删除它们.
您可以生成如下语句:DROP TABLE t1, t2, t3, ...
,然后使用准备好的语句执行它:
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;