Два одинаковых кусочка программного обеспечения с использованием общей базы данных - как это сделать лучше всего? - PullRequest
0 голосов
/ 21 декабря 2011

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

До сих пор мы фокусировались на одном особенно сложном гранте.Сейчас мы хотим расширить на другие гранты.Нашей первой целью был довольно упрощенный грант.Код для этого был просто навален на старое приложение.Теперь мы решили, что лучше всего разделить две программы (потому что не у всех наших клиентов есть оба гранта).В теории это звучит просто.

Мы можем довольно легко справиться со сложностью кода, вызванной этим, с помощью функции объединения патчей и SVN.Что гораздо сложнее, их база данных одинакова.Два гранта имеют несколько таблиц и несколько процедур.Но это довольно большая устаревшая база данных (более 40 таблиц, сотни хранимых процедур).

Каков наилучший способ разделить эти две базы данных, но при этом разделить их общие элементы?Мы не обеспокоены конфликтами между двумя приложениями, записывающими в одну и ту же БД (у нас есть блокировки для этого), а скорее нас беспокоят конфликты схем при разработке и обновлении серверов наших клиентов и управлении сложностью.

У нас есть несколько вариантов, о которых мы думали:

  1. Использование схем (shared, grant1, grant2)
  2. Использование префиксных имен

1 Ответ

2 голосов
/ 22 декабря 2011

Книга SQL Antipatterns имела решение для такого рода вещей.Распространение общих данных - это хорошо, просто переместите расширенные данные в отдельную таблицу, очень похоже на расширение класса в ООП.

Persons Table
--------------------------
PersonID      LastName       FirstName

FoodStamps Table (From Application 1)
--------------------------
PersonID      FoodStampAllotment

HousingGrant Table (From Application 2)
--------------------------
PersonID      GrantAmount

Вы можете добавить префиксы в расширенные таблицы, если хотите.

Этот запрос даст мне просто людей в программе FoodStamps:

SELECT * FROM Persons
  JOIN FoodStamps
  ON FoodStamps.PersonID = Persons.PersonID
...