Список вопросов
Как зайти в Даркнет?!
25th January, 01:11
174
0
Как в tkinter из поля ввода Entry получить значение в одну переменную и обновить строку кнопкой, затем получить ещё одно введённое значение и затем сложить их. Ниже пример кода
21st July, 19:00
1524
0
Программа, которая создает фейковые сервера в поиске игровых серверов CS 1.6 Steam
21st March, 17:43
1149
0
Очень долго работает Update запрос Oracle
27th January, 09:58
1057
0
не могу запустить сервер на tomcat HTTP Status 404 – Not Found
21st January, 18:02
1031
0
Где можно найти фрилансера для выполнения поступающих задач, на постоянной основе?
2nd December, 09:48
1072
0
Разработка мобильной кроссплатформенной военной игры
16th July, 17:57
1869
0
период по дням
25th October, 10:44
4087
0
Пишу скрипты для BAS только на запросах
16th September, 02:42
3849
0
Некорректный скрипт для закрытия блока
14th April, 18:33
4769
0
прокидывать exception в блоках try-catch JAVA
11th March, 21:11
4515
0
Помогите пожалуйста решить задачи
24th November, 23:53
6263
0
Не понимаю почему не открывается детальное описание продукта
11th November, 11:51
4479
0
Нужно решить задачу по программированию на массивы
27th October, 18:01
4560
0
Метода Крамера С++
23rd October, 11:55
4462
0
помогите решить задачу на C++
22nd October, 17:31
4127
0
Помогите решить задачу на python с codeforces
22nd October, 11:11
4608
0
Python с нуля: полное руководство для начинающих
18th June, 13:58
2731
0
Как работать с постоянно изменяющейся базой в системе контроля версий?
Просмотров: 425
 
Ответов: 6
Используем subversion, MySQL, NetBeans.
Хотелось бы чтобы окромя кода база тоже находилась бы в svn. База проекта обновляется достаточно часто. Как с наименьшими трудозатратами обновлять, фиксировать и т.п. таблицы, процедуры, вьюшки и т.п.?
Использую в работе следующий вариант:
- новая база всегда совместима с предыдущей версией кода (то есть обратная совместимость 1 на выкладку железно сохраняется — и если код придется откатить на старый, то с новой базой он будет работать корректно). на деле это выглядит так: если надо удалить какое-то поле в БД в выкладке N, то поле будет удалено только при выкладке N+1
- изменения в структуре БД от версии к версии сохраняются в файлах sql/alter/n.sql. выполненные изменения переносятся в /sql/alter/done. файлы нумеруются по-порядку, каждый разработчик создаем себе новый, чтобы измежать конфликтом при merge
В итоге при выкатке нового кода мы сперва выполняем alter'ы, потом выливаем код. В случае, если в коде есть ошибки — старый код гарантировано работает с новой базой.
В Rails подобная проблема решается при помощи механизма миграций. Каждое изменение БД описывается через DSL, а не применяется напрямую к базе. Получается, что миграции — это обычные файлы с исходным кодом, которые легко вносятся в ту же svn. Для PHP (если разработка на нём) можно либо поискать подходящую библиотеку, которая будет транслировать php-код в sql запросы, либо написать самостоятельно. Сложного там ничего нет.
Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться