我有这段代码:
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 中遇到了错误。
我该如何让这尽可能简单?
ALTER TABLE tablename ADD COLUMN IF NOT EXISTS columnname columntype;
命令添加列,如果该列不存在的话。 - Skippy le Grand Gourou