gpt4 book ai didi

mysql - 如何在没有 DROP 数据库权限的情况下从命令行删除所有 MySQL 表?

转载 作者:IT老高 更新时间:2023-10-28 12:48:33 25 4
gpt4 key购买 nike

如何使用命令提示符删除 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;

关于mysql - 如何在没有 DROP 数据库权限的情况下从命令行删除所有 MySQL 表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12403662/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com