Сведения о вопросе

Fhohir

18:15, 29th August, 2020

Теги

MySQL   Subversion    

Как работать с постоянно изменяющейся базой в системе контроля версий?

Просмотров: 408   Ответов: 6

Используем subversion, MySQL, NetBeans.


Хотелось бы чтобы окромя кода база тоже находилась бы в svn. База проекта обновляется достаточно часто. Как с наименьшими трудозатратами обновлять, фиксировать и т.п. таблицы, процедуры, вьюшки и т.п.?



  Сведения об ответе

Chhiki

03:15, 25th August, 2020

Обратите внимание на liquibase


  Сведения об ответе

Chhiki

22:14, 10th August, 2020

  Сведения об ответе

P_S_S

12:56, 9th August, 2020

хранить sql генерации базы?

использовать гибкую ORM которая позволяет хранить структуру бд в конфигах. типа hibernate для java или doctrine для php


  Сведения об ответе

ASSembler

08:01, 3rd August, 2020

Использую в работе следующий вариант:

  1. новая база всегда совместима с предыдущей версией кода (то есть обратная совместимость 1 на выкладку железно сохраняется — и если код придется откатить на старый, то с новой базой он будет работать корректно). на деле это выглядит так: если надо удалить какое-то поле в БД в выкладке N, то поле будет удалено только при выкладке N+1
  2. изменения в структуре БД от версии к версии сохраняются в файлах sql/alter/n.sql. выполненные изменения переносятся в /sql/alter/done. файлы нумеруются по-порядку, каждый разработчик создаем себе новый, чтобы измежать конфликтом при merge

В итоге при выкатке нового кода мы сперва выполняем alter'ы, потом выливаем код. В случае, если в коде есть ошибки — старый код гарантировано работает с новой базой.


  Сведения об ответе

appple

05:19, 6th August, 2020

Юзайте Git


  Сведения об ответе

darknet

03:52, 29th August, 2020

В Rails подобная проблема решается при помощи механизма миграций. Каждое изменение БД описывается через DSL, а не применяется напрямую к базе. Получается, что миграции — это обычные файлы с исходным кодом, которые легко вносятся в ту же svn. Для PHP (если разработка на нём) можно либо поискать подходящую библиотеку, которая будет транслировать php-код в sql запросы, либо написать самостоятельно. Сложного там ничего нет.


Ответить на вопрос

Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться