我在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');
CALL createLogTable('exampleTable');
所以基本思想是