首页 > 解决方案 > 如何删除 MySQL 中的所有过程和函数

问题描述

我想删除 MySQL 特定数据库中的所有过程和函数。我正在尝试使用这个存储过程来实现这一点。

但我收到一个错误:

错误代码:1295 准备好的语句协议尚不支持此命令。

提前致谢。

delimiter $$
CREATE PROCEDURE sp_drop_all_stored_procedures()
begin
    declare flag boolean default false;
    declare sql_drop_statement varchar(1000);
  
    declare statements cursor for SELECT
    CONCAT('DROP ',ROUTINE_TYPE, ' ', ROUTINE_NAME, ';') as stmt
    FROM information_schema.ROUTINES where ROUTINE_SCHEMA = 'DB_NAME' and 
    ROUTINE_NAME != sp_drop_all_stored_procedures;
    
    declare continue handler for not found set flag := true;

    open statements;
    statements_loop: loop
        fetch statements into sql_drop_statement;
        
        if flag then
            leave statements_loop;
        end if;

        set @drop_statement = sql_drop_statement;
        select @drop_statement;
        PREPARE stmt FROM @drop_statement;
        EXECUTE stmt;
        DEALLOCATE PREPARE stmt;  
        
    end loop statements_loop;
    close statements;
    
end $$
delimiter ;

标签: mysqlmysql-workbench

解决方案


可以作为准备好的语句执行的 SQL 语句列表记录在此处:https ://dev.mysql.com/doc/refman/8.0/en/sql-prepared-statements.html#prepared-statements-permitted (滚动向下大约三分之二的页面)。

DROP PROCEDURE 和 DROP FUNCTION 不在其中。

但是,即使您避免使用准备好的语句,您也无法做到这一点:

mysql> create procedure d() drop procedure p;
ERROR 1357 (HY000): Can't drop or alter a PROCEDURE from within another stored routine

因此,我认为您不能在存储过程中执行此操作。您必须从客户端执行此操作,您可以在其中格式化每个 SQL 语句并直接执行它,而不是作为准备好的语句。


推荐阅读