Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/9: Рейтинг темы: голосов - 9, средняя оценка - 4.78
16 / 16 / 10
Регистрация: 24.01.2014
Сообщений: 187
MySQL

Версионность БД при обновлении движка

13.06.2014, 12:58. Показов 1939. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Сейчас делаю небольшой форумный движок на PHP+MySQL - http://exbb.pw
Хочу сделать возможность автоматического обновления движка до новых версий, думаю над тем, как это можно сделать. При обновлении файлов можно просто заменить старый файл на новый (из архива с обновлением)
А вот при обновлении структуры базы данных хочу сделать что-то типа версионности (это вроде так называется)
Например есть запрос:

SQL
1
2
3
4
5
6
7
CREATE TABLE `test_table` (
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  `field1` INT(11) NOT NULL,
  `field2` INT(11) NOT NULL,
  `field3` VARCHAR(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
А в новой версии в эту таблицу были добавлены (изменены/удалены) поля.
Например в новой версии будет такой запрос:
SQL
1
2
3
4
5
6
7
8
CREATE TABLE `test_table` (
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  `field1` INT(11) NOT NULL,
  `field2` INT(11) NOT NULL,
  `field3` VARCHAR(255) NOT NULL,
  `field4` VARCHAR(255) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
Возможно ли как-то реализовать синхронизацию таблиц?
У меня SQL запросы хранятся в файле install/schema.sql
Чтобы при выполнении второго запроса в таблицу добавлялось новое поле `field4`, а остальные поля не изменялись, и главное, чтобы не менялось содержимое?

Или всё таки при каждом изменении структуры таблиц делать ALTER TABLE
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.06.2014, 12:58
Ответы с готовыми решениями:

Версионность при десериализации
Добрый день ,есть базовый класс ,и производные. нужно сериализовать лист объектов. Первым полем сохраняю номер версии. ...

Версионность при сериализации
Добрый день. Пишу игру под XNA. Нужна помощь с версионностью в сериализации. Есть метод private void...

Как реализовать версионность для rest api при посредстве паттерна фабричный метод?
Думаю как красиво написать rest api на php. Пытаюсь реализовать версионность. Вычитал, что надо для каждой версии создавать свою модель при...

1
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
14.06.2014, 08:59
WebProgrammer1, ну не знаю, припишите при создании поля "IF NOT EXISTS". Если поле есть - создано не будет, а если нет - создастся.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.06.2014, 08:59
Помогаю со студенческими работами здесь

Ошибка при обновлении данных в БД из DataGridView при определенном условии
Собственно проблема в следующем... в приложение добавил обновление БД из dgv. Сделано по примеру, как в видео _sB0A6FIhUM На...

Изменение цвета строки при загрузке формы и при обновлении
здравствуйте, В базе MySQL я создал столбец color_id. При полном выделении строки в datagridview и выбором цвета из combobox строка...

Версионность БД
Доброго времени суток, БДшники и сочувствующие. Подскажите в какую сторону смотреть, я в БД ноль. У меня есть удаленная БД есть oracle sql...

Версионность
Есть ли возможность настроить автоматическое обновление номера версии при компиляции/публикации/коммите? Как это осуществить, куда...

как сделать чтобы при при обновлении страницы (header('location .');) попадать на ту же позицию
Например у меня есть длинный список записей, под каждой записью кнопка удалить, когда нажимаешь на нее, то происходит удаление записи и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru