Mysql动态sql语句,用当前时间做表名

  在mysql备份操作中, 我们可能要使用表名和当前时间来做为备份表的名称,但是MySQL在存储过程中不支持使用变量名来做表名或者列名。

  例如:有一个表”user“,我需要备份一份,并且表名为“user_2017_02_21“。

 

  在MySQL5.1以上的版本中,prepare语句可以支持这样的操作。
  我们可以用set @var=...设置变量,然后用prepare stml from @var设置动态sql语句,最后用EXECUTE stml;执行语句。

     下面是以时间为表名,动态备份一个表的sql执行过程:

  

SET @sqlstr = CONCAT('create table user_',DATE_FORMAT(CURDATE(),'%Y_%m_%d'),' like user');
PREPARE stmt1 FROM @sqlstr ;
EXECUTE stmt1 ;
SET @sqlstr = CONCAT('insert into user_',DATE_FORMAT(CURDATE(),'%Y_%m_%d'),' select * from user');
PREPARE stmt1 FROM @sqlstr ;
EXECUTE stmt1 ;

 

posted @ 2017-02-27 09:56  doforme  阅读(7800)  评论(1编辑  收藏  举报