sql >> Databáze >  >> RDS >> Mysql

mysql vytvořit tabulku dynamicky

Aby řetězec představoval název tabulky (nebo databáze), budete muset spojit řetězec dotazu s proměnnou a připravit/provést příkaz přímo v uložené proceduře. Zde je základní příklad.

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

Potom… CALL createLogTable('exampleTable');

Základní myšlenka je tedy

  1. podle potřeby spojte parametry procedury s vaším dotazem
  2. připravte/proveďte příkaz z tohoto řetězce dotazu



  1. Nemohu nastavit více obrázků v zobrazení mřížky?

  2. Jak získat data BLOB pomocí oracle ODBC

  3. Záloha SQL Server 2017 -1

  4. Provádění matematické operace na dočasném sloupci v SQL