mysql动态创建表

我在mysql上创建数据库。首先创建主体表,每个表平均有30列。日志表的标准是引用表的pk加上每列*2。像这样:

Field   |   Type      |   Null   |   Key   |   Default   |   Extra

--------+-------------+----------+---------+-------------+----------------

TableID | int(11) | No | PRI | Null | auto_increment

Col1 | varchar(50) | No | | Null |

Field       |   Type      |   Null   |   Key   |   Default   |   Extra

------------+-------------+----------+---------+-------------+----------------

LogTableID | int(11) | No | PRI | Null | auto_increment

TableID | int(11) | No | MUL | Null |

NewCol1 | varchar(50) | No | | Null |

UpdatedCol1 | varchar(50) | No | | Null |

现在,我想要创建一个过程,在该过程中,我将表名作为参数传递,并生成表日志查询并执行它。

做这个的最好方式是什么?

回答:

为了使一个字符串代表一个表(或数据库)名称,您将需要用变量连接查询字符串,并在存储过程中准备/执行一条语句。这是一个基本示例。

-- DROP PROCEDURE IF EXISTS createLogTable;

DELIMITER //

CREATE PROCEDURE createLogTable(tblName VARCHAR(255))

BEGIN

SET @tableName = tblName;

SET @q = CONCAT('

CREATE TABLE IF NOT EXISTS `' , @tableName, '` (

`id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,

`something` VARCHAR(10) NOT NULL,

`somedate` DATETIME NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf8

');

PREPARE stmt FROM @q;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

-- and you're done. Table is created.

-- process it here if you like (INSERT etc)

END //

然后… CALL createLogTable('exampleTable');

所以基本思想是

  1. 根据需要将过程参数与查询联系起来
  2. 从此查询字符串准备/执行语句

以上是 mysql动态创建表 的全部内容, 来源链接: utcz.com/qa/402703.html

回到顶部