Предложение по дизайну базы данных - несколько таблиц участвуют в отношениях - PullRequest
1 голос
/ 02 апреля 2011

Мое приложение должно реализовать отношение один к одному между несколькими таблицами.У меня есть таблица, в которой хранятся компании (которые могут быть покупателями и поставщиками или и тем, и другим).Есть двухбитные поля, Клиент и Поставщик.

Тогда у меня есть разные таблицы для различных операций: счета-фактуры, банковские операции, операции Cashdesk.Мне нужно связать платежи со счетами.Платеж не является точной суммой счета, но его можно разделить на каждое количество счетов.Кроме того, счет может быть разделен на несколько платежей.Платежи могут быть как из банковских, так и из кассовых операций

Мой оригинальный подход заключался в том, чтобы иметь таблицу PaymentRelations с внешними ключами InvoiceID, BankOpID, CashOpID и Amount, и для любого платежа между ними я создаю запись сзаполнены только два иностранных удостоверения личности и соответствующая сумма.Таким образом, в любой момент я могу узнать для каждой операции (счет или платеж), сколько было оплачено.

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

Но появилась другая ситуация.Поскольку партнеры могут быть как клиентами, так и поставщиками, можно компенсировать один и тот же тип операции на стороне клиента и поставщика одного и того же партнера (например, партнер является как клиентом, так и поставщиком, он выставил счет в качестве поставщика на 100 и получил счет-фактуру).как клиент на 150, 50 получил компенсацию между полученным и отправленным счетом, а остальная часть оплачивается через одну или несколько платежных операций).Это может также произойти для других операций (например, он оплатил через банковскую операцию 100, он получил через другую банковскую операцию 200, и между этими двумя операциями должна быть произведена компенсация 50; то же самое относится и к операциям caskdesk).

Какой подход вы бы использовали для моделирования такого рода отношений?

1 Ответ

3 голосов
/ 14 апреля 2011

Я бы купил бы бухгалтерское программное обеспечение вместо того, чтобы писать его.Некоторые колеса стоит изобретать;это не один из них.

Но если нужно.,.

Битовые поля - это неправильный способ идентификации клиентов и поставщиков. Этот SO-ответ поможет вам решить проблемы с клиентами и поставщиками.

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

Разработав рабочую (ish) модель в электронной таблице, я бы затем попыталсянормализуйте его до 5NF.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...