Мои исследования и эксперименты еще не дали ответа, поэтому я надеюсь на некоторую помощь.
Я изменяю установочный файл приложения, в котором в предыдущих версиях не было столбца, который я хочу добавить сейчас. Я не хочу добавлять столбец вручную, а в установочный файл и только в том случае, если новый столбец еще не существует в таблице.
Таблица создается следующим образом:
CREATE TABLE IF NOT EXISTS `#__comm_subscribers` (
`subscriber_id` int(11) NOT NULL auto_increment,
`user_id` int(11) NOT NULL default '0',
`subscriber_name` varchar(64) NOT NULL default '',
`subscriber_surname` varchar(64) NOT NULL default '',
`subscriber_email` varchar(64) NOT NULL default '',
`confirmed` tinyint(1) NOT NULL default '0',
`subscribe_date` datetime NOT NULL default '0000-00-00 00:00:00',
PRIMARY KEY (`subscriber_id`),
UNIQUE KEY `subscriber_email` (`subscriber_email`)
) ENGINE=MyISAM CHARACTER SET 'utf8' COLLATE 'utf8_general_ci' COMMENT='Subscribers for Comm are stored here.';
Если я добавлю следующее под оператором создания таблицы, я не уверен, что произойдет, если столбец уже существует (и, возможно, заполнен):
ALTER TABLE `#__comm_subscribers` ADD `subscriber_surname`;
ALTER TABLE `#__comm_subscribers` MODIFY `subscriber_surname` varchar(64) NOT NULL default '';
Итак, я попробовал следующее, которое где-то нашел. Похоже, это не работает, но я не совсем уверен, что использовал его правильно.
/*delimiter '//'
CREATE PROCEDURE addcol() BEGIN
IF NOT EXISTS(
SELECT * FROM information_schema.COLUMNS
WHERE COLUMN_NAME='subscriber_surname' AND TABLE_NAME='#__comm_subscribers'
)
THEN
ALTER TABLE `#__comm_subscribers`
ADD COLUMN `subscriber_surname` varchar(64) NOT NULL default '';
END IF;
END;
//
delimiter ';'
CALL addcol();
DROP PROCEDURE addcol;*/
У кого-нибудь есть хороший способ сделать это?
Ответы:
Обратите внимание, что
INFORMATION_SCHEMA
это не поддерживается в MySQL до 5.0. Хранимые процедуры не поддерживаются и до 5.0, поэтому, если вам нужно поддерживать MySQL 4.1, это решение не подходит.Одним из решений, используемых фреймворками, использующими миграции баз данных, является запись в базу данных номера редакции схемы. Просто таблица с одним столбцом и одной строкой, с целым числом, указывающим, какая ревизия является текущей в силе. Когда вы обновляете схему, увеличивайте число.
Другим решением было бы просто попробовать на
ALTER TABLE ADD COLUMN
команду. Он должен выдать ошибку, если столбец уже существует.Поймайте ошибку и проигнорируйте ее в сценарии обновления.
источник
--force
переключатель, что означает продолжение работы даже в случае ошибки. тогда просто дерзай. вы просто хотите быть уверены, что нет никаких заявлений, которые вы НЕ хотите добиться, если что-то предыдущее не удалось.Вот рабочее решение (только что опробовано с MySQL 5.0 на Solaris):
На первый взгляд, это может показаться сложнее, чем должно быть, но здесь нам приходится иметь дело со следующими проблемами:
IF
операторы работают только в хранимых процедурах, а не при прямом запуске, например, в клиенте mysqlSHOW COLUMNS
не работает в хранимой процедуре, поэтому необходимо использовать INFORMATION_SCHEMATABLE_SCHEMA=DATABASE()
.DATABASE()
возвращает имя текущей выбранной базы данных.источник
Если вы используете MariaDB, нет необходимости использовать хранимые процедуры. Просто используйте, например:
Посмотреть здесь
источник
Большинство ответов касаются того, как безопасно добавить столбец в хранимую процедуру, у меня возникла необходимость добавить столбец в таблицу без использования хранимой процедуры, и я обнаружил, что MySQL не позволяет использовать
IF Exists()
вне SP . Я опубликую свое решение, которое может помочь кому-то в такой же ситуации.источник
Другой способ сделать это - игнорировать ошибку с помощью
declare continue handler
:Я думаю, что так лучше, чем с
exists
подзапросом. Особенно, если вам нужно добавить много столбцов и вы хотите запустить скрипт несколько раз.дополнительную информацию об обработчиках продолжения можно найти на http://dev.mysql.com/doc/refman/5.0/en/declare-handler.html
источник
Я использую MySQL 5.5.19.
Мне нравятся сценарии, которые можно запускать и запускать повторно без ошибок, особенно когда кажется, что предупреждения задерживаются и появляются снова позже, когда я запускаю сценарии, в которых нет ошибок / предупреждений. Что касается добавления полей, я написал себе процедуру, чтобы немного меньше печатать:
Код для создания процедуры addFieldIfNotExists выглядит следующим образом:
Я не писал процедуру для безопасного изменения столбца, но я думаю, что описанную выше процедуру можно легко изменить для этого.
источник
Я взял sproc OP и сделал его многоразовым и независимым от схемы. Очевидно, для этого по-прежнему требуется MySQL 5.
источник
Только что попробовал сценарий хранимой процедуры. Кажется, проблема в
'
метках вокруг разделителей. В MySQL Docs показывают , что символы - ограничители не нужны одиночные кавычки.Итак, вы хотите:
Вместо того:
Работает для меня :)
источник
Если вы запускаете это в сценарии, вам нужно будет добавить следующую строку позже, чтобы сделать ее запускаемой повторно, иначе вы получите ошибку процедуры, уже существующей.
источник
Лучший способ добавить столбец в PHP> PDO:
Примечание: столбец в таблице не повторяется, это означает, что нам не нужно проверять наличие столбца, но для решения проблемы мы проверяем приведенный выше код:
например, если он работает, предупреждение 1, если не 0, что означает, что столбец существует! :)
источник
Проверить, существует ли столбец в PDO (100%)
источник
Процедура от Джейка https://stackoverflow.com/a/6476091/6751901 - очень простое и хорошее решение для добавления новых столбцов, но с одной дополнительной строкой:
вы можете добавить туда новые столбцы позже, и это будет работать и в следующий раз:
источник
Затем в $ res по циклу найдите ключ своего столбца Smth следующим образом:
источник
SHOW fields FROM __TABLE__NAME__ where field='_my_col_';
а затем проверить, не является ли набор результатов непустымНиже представлена хранимая процедура в MySQL для добавления столбца (столбцов) в разные таблицы в разных базах данных, если столбец не существует в таблице (ах) базы данных, со следующими преимуществами.
источник
источник