如何在没有DROP数据库权限的情况下从命令行删除所有MySQL表??mysql-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

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

保持可爱mmm 2020-05-17 18:23:31 102

如何使用命令提示符删除Windows MySQL中的所有表?我要执行此操作的原因是,我们的用户有权访问数据库,但不能访问重新创建数据库本身,因此,我们必须手动删除表。有没有一种方法可以一次删除所有表?请记住,大多数表都与外键链接,因此必须按特定顺序删除它们。

关系型数据库 MySQL 数据库 Windows
分享到
取消 提交回答
全部回答(1)
  • 保持可爱mmm
    2020-05-17 18:36:33

    您可以生成如下语句: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; 来源:stack overflow

    0 0
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

推荐文章
相似问题
推荐课程