返回顶部

收藏

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. smalleyes 发表 2014-10-16 03:32:30 调用存储过程出错ERROR 1436 (HY000): Thread stack overrun:
  2. smalleyes 发表 2014-10-16 08:50:58 存储过程之查看
  3. smalleyes 发表 2014-10-16 09:59:53 存储过程之变量
  4. 胡 志伟 发表 2014-04-09 09:37:26 Mysql存储过程计算留存率
  5. viggo 发表 2015-12-04 23:19:39 mysql通过存储过程生成流水号(订单编号)
  6. OurMySQL 发表 2014-11-25 23:11:25 PHP调用存储过程返回值不一致的问题
  7. hellojinjie 发表 2014-03-04 10:39:40 Linux Ext4 文件系统对 MySQL 性能的影响
  8. 博主 发表 2015-03-31 08:44:10 MySQL数据库引擎详解
  9. admin 发表 2009-02-13 02:45:56 导入导出MySQL数据库SQL文件
  10. admin 发表 2015-05-08 08:06:00 20150506杨万敏-mysql数据库切分
  11. Rady Huang 发表 2011-12-08 16:24:17 USING BTREE引起的MySQL导入错误
  12. saymoon 发表 2011-09-10 14:36:14 mysql随机抽取前N条纪录

发表评论