Итак, на самом деле здесь есть два вопроса. Управление данными и управление пролетным путем.
Что касается управления данными, да, это должно быть отдельной вещью. Данные растут и растут. Попытка управлять данными, помимо простых таблиц поиска, из системы управления версиями быстро становится очень проблематичной. Не говоря уже о том, что вам нужны разные данные в разных средах. Это также значительно усложняет автоматизацию развертываний (ветвление было бы вашим другом, если вы настаиваете на том, чтобы идти по этому маршруту, по одной ветке для каждого набора данных, а затем развертывать соответствующим образом).
Вы можете реализовать Flyway в существующем проекте, да . Ключевым моментом является установление базовой линии. Вам не нужно делать все шаги, описанные выше. Допустим, у вас есть существующая база данных. Вы должны получить сценарий, определяющий эту базу данных. Этот единственный сценарий должен включать весь соответствующий DDL (и, если хотите, DML). Назовите его в соответствии со стандартами Flyway. Что-то вроде V1.0__Baseline. sql.
После этого все, что вам нужно сделать, это запустить:
flyway baseline
Это установит sh существующую базу кода в качестве начала точка. Оттуда вам просто нужно создать сценарии в соответствии со стандартом именования: V1.1xxx V2.0xxx V53000.1xxx. И запустите
flyway migrate
, чтобы внедрить соответствующие изменения.
Единственное предостережение в том, что, как указано в документации, вы должны убедиться, что все ваши базы данных соответствуют этой версии V1.0, которую вы ' воссоздание и разметка в качестве базовой линии. Любое отклонение вызовет ошибки по мере того, как вы вводите новые изменения и переносите их на место. Если у вас есть совпадающие базовые точки, вы сможете без проблем работать с разными данными в разных средах.