mysql动态创建表

jcv*_*gan 3 mysql

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

参考表:

Field   |   Type      |   Null   |   Key   |   Default   |   Extra
--------+-------------+----------+---------+-------------+----------------
TableID | int(11)     | No       | PRI     | Null        | auto_increment
Col1    | varchar(50) | No       |         | Null        |
Run Code Online (Sandbox Code Playgroud)

记录表:

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        |
Run Code Online (Sandbox Code Playgroud)

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

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

inh*_*han 5

要使字符串表示表(或数据库)名称,您需要将查询字符串与变量连接起来,并在存储过程中准备/执行语句.这是一个基本的例子.

-- 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 //
Run Code Online (Sandbox Code Playgroud)

然后… CALL createLogTable('exampleTable');

所以基本的想法是

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