Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4011511
  • 博文数量: 626
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 11080
  • 用 户 组: 普通用户
  • 注册时间: 2012-08-23 13:08
文章分类

全部博文(626)

文章存档

2015年(72)

2014年(48)

2013年(506)

分类: Mysql/postgreSQL

2013-10-08 10:43:01

MySQL存储过程使用表名做参数


原创文章,chszs版权所有!
如要转发,请联系chszs!
盗贴行为将受起诉!

MySQL存储过程使用表名做参数动态创建表的例子。

一同学向我请教在MySQL的存储过程中,如何使用表名做参数动态创建表。

这个问题在MySQL 5.0以前非常麻烦,但是在MySQL 5.0.13版之后,由于引入了PREPARE语句,一切变得简单了。

此问题在网上搜索的帖子一般都是错误的!

例子如下(已验证):

  1. DROP PROCEDURE IF EXISTS `newtable`;  
  2. CREATE PROCEDURE `newtable`(IN tname varchar(64))  
  3. BEGIN  
  4. SET @sqlcmd = CONCAT('CREATE TABLE ', tname, ' (id int NOT NULL AUTO_INCREMENT, name varchar(64) DEFAULT NULL, PRIMARY KEY (`id`))');  
  5. PREPARE stmt FROM @sqlcmd;  
  6. EXECUTE stmt;  
  7. DEALLOCATE PREPARE stmt;  
  8. END;  
  9. call newtable('abc');  


阅读(3263) | 评论(0) | 转发(0) |
0

上一篇:Spring Roo开发初评

下一篇: XINS Web服务框架

给主人留下些什么吧!~~