0
点赞
收藏
分享

微信扫一扫

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


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

原创文章,chszs版权所有!

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

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

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

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

例子如下(已验证):

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

举报

相关推荐

0 条评论