MySQL 动态sql语句执行 用时间做表名

1. 描述

  在使用数据的时候,我时候我们需要很多数据库,而且想用时间来做表名以区分。但是MySQL在存储过程中不支持使用变量名来做表名或者列名。
  比如,有一个表我们想以“2015-07-16 12:00:00”命名。


2. 解决方案

  如果只是更换一个普通的表名的话,很简单,直接使用下面sql语句即可:
  alter table old_table_name rename new_table_name
  但是要以时间为表名,动态命名的话就不可以了。首先我们可以用NOW()函数获取系统当前的时间。要寻求支持动态以变量的形式做数据库操作的方法,在MySQL5.1以上的版本中,prepare语句可以支持这样的操作。
  我们可以用set @var=...设置变量,然后用prepare stml from @var设置动态sql语句,最后用EXECUTE stml;执行语句。
  下面是以时间为表名,动态修改一个表的sql执行过程:
  

set @asql=concat('alter table old_table_name rename `',NOW(),'`');
prepare stml from @asql;
EXECUTE stml;

  这里使用到了MySQL中concat函数,此函数的作用是字符串拼接。相信懂得编程的同学对此都不陌生。
  使用方法:
  concat(str1,str2,…)

  返回结果为连接参数产生的字符串。注意如有任何一个参数为NULL ,则返回值为 NUL。
  附一张结运行果图:
  re

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值