У меня есть этот код:
ALTER TABLE 'settings'
ADD COLUMN 'multi_user' TINYINT(1) NOT NULL DEFAULT 1
И я хочу изменить эту таблицу, только если этот столбец не существует.
Я пробую много разных способов, но ничего не получается:
ALTER TABLE 'settings'
ADD COLUMN IF NOT EXISTS 'multi_user' TINYINT(1) NOT NULL DEFAULT 1
С процедурой:
DELIMITER $$
CREATE PROCEDURE Alter_Table()
BEGIN
DECLARE _count INT;
SET _count = ( SELECT COUNT(*)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'settings' AND
COLUMN_NAME = 'multi_user');
IF _count = 0 THEN
ALTER TABLE 'settings' ADD COLUMN 'multi_user' TINYINT(1) NOT NULL DEFAULT 1
END IF;
END $$
DELIMITER ;
Я получил ошибку в END IF, затем в END, а затем в 1
Как я могу сделать это как можно проще?