mysql批量添加或者更新字段-存储过程sql

-- 存储过程存在则删除
DROP PROCEDURE IF EXISTS update_utime_sql;
-- 创建存储过程
CREATE PROCEDURE update_utime_sql(tableSchema VARCHAR(255))
-- 开始
BEGIN
    -- 定义游标变量
    DECLARE cursorIndex INT DEFAULT 0;
    -- 定义表名变量
    DECLARE tableName VARCHAR(255);
    -- 定义游标,并将sql结果集赋值到游标中
    DECLARE tableNames CURSOR FOR SELECT table_name AS tableName FROM information_schema.tables WHERE table_schema = tableSchema ORDER BY table_name;
-- 声明当游标遍历完后将标志变量置成某个值
DECLARE CONTINUE HANDLER FOR NOT FOUND SET cursorIndex = 1;
    -- 打开游标
OPEN tableNames;
-- 初始化表名变量
FETCH tableNames INTO tableName;
-- 循环添加表信息
WHILE cursorIndex <> 1
        DO
-- 拼接租户字段添加语句
SET @updateColumnSql = concat('ALTER TABLE ', tableSchema, '.', tableName, ' MODIFY COLUMN `utime` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT ''更新时间''');
                -- 把添加字段的语句赋值给一个预定义的值
PREPARE updateColumnSql from @updateColumnSql;
-- 执行添加字段的sql
EXECUTE updateColumnSql;
-- 释放预定义语句的资源
DEALLOCATE PREPARE updateColumnSql;
            -- 将游标中的值再赋值给变量,供下次循环使用
FETCH tableNames INTO tableName;
END WHILE;
    -- 关闭游标
CLOSE tableNames;
-- 结束
END;

CALL update_utime_sql('lc_salary');

 

posted @ 2022-07-29 17:43  二次元的程序猿  阅读(988)  评论(0)    收藏  举报