返回顶部

收藏

Mysql 删除所有表,需要考虑外键约束

更多

下面存储过程,使用游标遍历information_schema库里的tables表来实现:

CREATE PROCEDURE `drop_all_tables`()
BEGIN
    DECLARE _done INT DEFAULT FALSE;
    DECLARE _tableName VARCHAR(255);
    DECLARE _cursor CURSOR FOR
        SELECT table_name 
        FROM information_schema.TABLES
        WHERE table_schema = SCHEMA();
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET _done = TRUE;

    SET FOREIGN_KEY_CHECKS = 0;

    OPEN _cursor;

    REPEAT FETCH _cursor INTO _tableName;

    IF NOT _done THEN
        SET @stmt_sql = CONCAT('DROP TABLE ', _tableName);
        PREPARE stmt1 FROM @stmt_sql;
        EXECUTE stmt1;
        DEALLOCATE PREPARE stmt1;
    END IF;

    UNTIL _done END REPEAT;

    CLOSE _cursor;
    SET FOREIGN_KEY_CHECKS = 1;
END

使用这个存储过程可以方便的删除所有数据表

标签:mysql,存储过程,游标

收藏

0人收藏

支持

0

反对

0

相关聚客文章
  1. 胡 志伟 发表 2014-04-09 09:37:26 Mysql存储过程计算留存率
  2. viggo 发表 2015-12-04 23:19:39 mysql通过存储过程生成流水号(订单编号)
  3. OurMySQL 发表 2014-11-25 23:11:25 PHP调用存储过程返回值不一致的问题
  4. smalleyes 发表 2014-10-16 03:32:30 调用存储过程出错ERROR 1436 (HY000): Thread stack overrun:
  5. smalleyes 发表 2014-10-16 08:50:58 存储过程之查看
  6. smalleyes 发表 2014-10-16 09:59:53 存储过程之变量
  7. colinhu 发表 2012-12-02 08:47:07 LAMP架构相关书籍介绍
  8. 二愣子小强 发表 2012-11-19 05:48:45 cmd命令行导入mysql数据
  9. tenking 发表 2013-03-31 12:31:19 MySql逻辑备份恢复方法简单总结
  10. master 发表 2013-04-12 16:21:07 mysqlslap 一个MySQL数据库压力测试工具
  11. admin 发表 2012-05-28 14:16:11 Mac OS X 安装mysql过程
  12. yejr 发表 2012-08-20 09:25:32 [MySQL FAQ]系列-字符集兼容性测试

发表评论