mysql存储过程模糊查询_Mysql之存储过程“模糊查询drop表”

本文介绍了如何创建一个存储过程,通过遍历`information_schema.tables`中符合`table_schema='eqiurong'`且表名包含'2016%'的表,然后逐个使用`DROP TABLE IF EXISTS`语句删除这些表。
摘要由CSDN通过智能技术生成

需求:

清空 show tables like "%2016%"

实现:

DELIMITER //

drop procedure if exists p_clean_table;

create PROCEDURE p_clean_table(in tab varchar(128))

begin

DECLARE name VARCHAR(64);

-- 遍历数据结束标志

DECLARE done INT DEFAULT FALSE;

DECLARE tables_cur CURSOR FOR select table_name from information_schema.tables where table_schema='eqiurong' and table_name like '%2016%';

-- 将结束标志绑定到游标

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;

-- 打开游标

OPEN tables_cur;

-- 开始循环

read_loop: LOOP

-- 提取游标里的数据,这里只有一个,多个的话也一样;

FETCH tables_cur INTO name;

-- 声明结束的时候

IF done THEN

LEAVE read_loop;

END IF;

-- 这里做你想做的循环的事件

set @bsql :=concat("drop table if exists ",name);

PREPARE STMT FROM @bsql;

EXECUTE STMT ;

END LOOP;

-- 关闭游标

CLOSE tables_cur;

end;

//

DELIMITER ;

ps:

存储过程语法:

create PROCEDURE p_xx(in p1 varchar(128),out p2 varchar(128))

begin

............

end;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值