-- 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 改关键字就是用来做重定义分割符号的 默认是 分号;但是笔者执行创建存储过程时没有创建成功,故注释掉了;
最后一行是调用存储过程,输入 修改的表名, 操作类型这里目前笔者未输入,最后是你的行名称。