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');
随笔看心情