使用mysql存储过程删除万级数据

存储过程概念:

存储过程 相当于 java 当中的一个方法,可以传参,可以进行循环。

使用mysql存储过程删除万级数据

1、创建 存储过程

create procedure deleteOrder(in p_in int) -- in为输入的意思 p_in
-- 为输入的变量 int为变量类型
begin
    -- 定义变量
    DECLARE v_i int unsigned DEFAULT 0;
    WHILE v_i < p_in
        DO
        -- 输出变量
            SELECT v_i; 
            SET v_i = v_i + 1;
            -- 删除数据sql, 此处使用 limit 关键字来快速删除数据,这样可以不会锁表,cpu 也不--- 会爆满
            delete
            from wl_order
            where create_time between "2022-05-01" and "2022-06-01"
              and order_status = 13
              and order_fee is null
            limit 500;
        END WHILE;
end;

2、执行存储过程

call deleteOrder();

3、删除存储过程

drop procedure if exists deleteOrder;

4、查看存储过程定义

SHOW CREATE PROCEDURE 存储过程名称;

5、查询所有存储过程

show procedure status;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员西柚柚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值