sql >> Database >  >> RDS >> Mysql

mysql tabel dynamisch maken

Om een ​​string een tabelnaam (of databasenaam) te laten vertegenwoordigen, moet u uw querystring samenvoegen met de variabele en een instructie voorbereiden/uitvoeren in de opgeslagen procedure. Hier is een eenvoudig voorbeeld.

-- 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 //

Dan... CALL createLogTable('exampleTable');

Het basisidee is dus

  1. concat de procedureparameter(s) indien nodig met uw vraag
  2. een instructie van deze queryreeks voorbereiden/uitvoeren



  1. Postgresql OP CONFLICT in sqlalchemy

  2. MySQL:tel je twee dingen in één query?

  3. Op de juiste manier samengestelde primaire sleutels maken - MYSQL

  4. MySQL - Supertype/Subtype-ontwerp