sql >> Databasteknik >  >> RDS >> Mysql

mysql skapa tabell dynamiskt

För att få en sträng att representera ett tabell- (eller databasnamn) måste du sammanfoga din frågesträng med variabeln och förbereda/köra en sats direkt i den lagrade proceduren. Här är ett grundläggande exempel.

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

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

Så grundidén är

  1. Sätt ihop procedurparametrarna med din fråga vid behov
  2. förbered/kör en sats från den här frågesträngen



  1. Postgres:Kan vi ha kolumn för automatisk ökning i sammansatt nyckel

  2. Infogar data från frontend till mysql db i angularjs

  3. Kör prestanda i en hybridmolninstallation

  4. MySQL Second (eller tredje) Index Of in String