记录MySQl 编写存储过程问题

-- DELIMITER //
CREATE procedure alter_table_structure(_table_name VARCHAR(100), operTpe VARCHAR(100), colum varchar(100))
BEGIN
    DECLARE done INT DEFAULT FALSE;
    DECLARE vtable_name varchar(100);
    DECLARE cur CURSOR for
        SELECT table_name
        FROM information_schema.tables
        WHERE TABLE_name like concat(_table_name, '%');

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;

OPEN cur;
read_loop: LOOP
    FETCH cur INTO vtable_name;
    IF done THEN
        LEAVE read_loop;
    END IF;

    -- 执行修改表结构的操作
    -- ...
    SET @alter_stmt = concat(CONCAT('ALTER TABLE ', vtable_name, ' add column '),  colum, ' varchar(64) default null');
    PREPARE stmt FROM @alter_stmt;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
END LOOP;

CLOSE cur;


end; -- //
-- DELIMITER ;
call alter_table_structure('tableaName', '', 'newColum' );

笔者的需求是很简单: 由于数据库中有些表进行了分表,所以现在这个表需要新增字段,但是同一表数据库中有很多,所以需要批量的修改这些表,故此琢磨了下

改存储过程支持参数输入,操作类型(需要改在sql 新增 判断语句 拼接sql);一开始sql前面和后面都加了关键字:DELIMITER 改关键字就是用来做重定义分割符号的 默认是 分号;但是笔者执行创建存储过程时没有创建成功,故注释掉了;

最后一行是调用存储过程,输入 修改的表名, 操作类型这里目前笔者未输入,最后是你的行名称。

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值