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 @   二次元的程序猿  阅读(979)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
点击右上角即可分享
微信分享提示