MySQL: возможно ли хранить тип в переменной и использовать его в выражении [duplicate]

Извинения за то, что вы не используете ваш точный SQL

Я использовал этот запрос для преодоления предупреждения Mysql.

SELECT count(*) AS cnt, `regions_id`
FROM regionables 
WHERE `regionable_id` = '115' OR `regionable_id` = '714'
GROUP BY `regions_id`
HAVING cnt > 1

обратите внимание на ключ для меня:

count(*) AS cnt
3
задан John Peter 17 January 2013 в 14:44
поделиться

1 ответ

Чтобы строка представляла имя таблицы (или базы данных), вам нужно будет выполнить последовательность строк запроса с помощью переменной и подготовить / выполнить инструкцию непосредственно в хранимой процедуре. Вот основной пример:

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

Затем ... CALL createLogTable('exampleTable');

Итак, основная идея:

  1. concat параметр (ы) процедуры с ваш запрос по мере необходимости
  2. подготовить / выполнить инструкцию из этой строки запроса
5
ответ дан inhan 26 August 2018 в 21:38
поделиться
Другие вопросы по тегам:

Похожие вопросы: