mysql 添加字段_mysql存储过程全表添加字段

BEGIN

#Routine body goes here...

DECLARE tName VARCHAR (64) ;

  DECLARE done INT DEFAULT FALSE ;

  DECLARE cur CURSOR FOR 

  SELECT 

    table_name 

  FROM

    information_schema.tables 

  WHERE table_schema = dateName and table_name like 'test%' ;

  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE ;

  OPEN cur ;

  posLoop :

  LOOP

    FETCH cur INTO tName ;

    IF done 

    THEN LEAVE posLoop ;#

    END IF;

#判断表中是否有这个字段

IF (SELECT count(1) FROM information_schema.COLUMNS

WHERE

COLUMN_NAME = 'is_del'

AND TABLE_NAME = tName)<=0 then

#执行语句同上CONCAT来拼接动态参数(注意拼接过程中的空格,引号等)

SET @_sqlStr=CONCAT('ALTER TABLE ',tName ," ADD COLUMN `is_del` varchar(8) NOT NULL DEFAULT '10010002' COMMENT '是否删除:10010001是,10010002否';");

#ALTER TABLE test ADD COLUMN `is_del`  varchar(8) NOT NULL DEFAULT '10010002' COMMENT '是否删除:10010001是,10010002否;'

# 预定义sql   预定义拼接好的sql语句

PREPARE stmt FROM @_sqlStr ;

# 执行sql

EXECUTE stmt ;

# 释放连接

DEALLOCATE PREPARE stmt ;

END if;

  END LOOP posLoop ;

  CLOSE cur ;

END

设置存储过程的参数时需要添加上参数长度

50c1938e1aaf1a0a330faf889700bff7.png

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值