sql >> Database teknologi >  >> RDS >> Mysql

mysql opret tabel dynamisk

For at få en streng til at repræsentere et tabel- (eller databasenavn) skal du sammenkæde din forespørgselsstreng med variablen og forberede/udføre en sætning direkte i den lagrede procedure. Her er et grundlæggende eksempel.

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

Så... CALL createLogTable('exampleTable');

Så grundideen er

  1. sammensæt procedureparametrene med din forespørgsel efter behov
  2. forbered/udfør en sætning fra denne forespørgselsstreng



  1. Hvordan undgår man at SSIS FTP-opgave mislykkes, når der ikke er nogen filer at downloade?

  2. Bedste måde at fange sql unikke begrænsninger i c# under indsættelser

  3. Sequelize opretter ikke fremmednøgler som begrænsninger

  4. MySQL Hosting på Azure, Fuldt administreret Cloud Database Service lanceres på ScaleGrid