Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 02.09.2013, 20:45
kvadratnt kvadratnt вне форума
Прохожий
 
Регистрация: 07.06.2009
Сообщения: 6
Репутация: 10
По умолчанию Access. БД по накладной. Укажите на ошибки

Добрый вечер.
Реализовываю документ "Накладная" в access. Проверьте пожалуйста схему данных.

С уважением Василий.

Сама накладная на первом рисунке, схема данных во втором.
Изображения
Тип файла: jpg Изображение 091.jpg (60.6 Кбайт, 9 просмотров)
Тип файла: jpg Схема данных.jpg (42.7 Кбайт, 9 просмотров)
Ответить с цитированием
  #2  
Старый 02.09.2013, 20:51
kvadratnt kvadratnt вне форума
Прохожий
 
Регистрация: 07.06.2009
Сообщения: 6
Репутация: 10
По умолчанию

Вот тут получше видно
Изображения
Тип файла: jpg Схема данных.jpg (76.3 Кбайт, 8 просмотров)
Ответить с цитированием
  #3  
Старый 02.09.2013, 21:34
Аватар для Uniq!
Uniq! Uniq! вне форума
Местный
 
Регистрация: 29.09.2010
Сообщения: 539
Версия Delphi: Delphi XE3
Репутация: 374
По умолчанию

Принято делать чуть иначе:

Таблицу называют "накладнЫЕ" или "Invoices" (ибо там будет куча документов, а не один)
У каждой таблицы должно быть (по книгам и по опыту) поле ID (тип автоинкремент - увеличение на 1цу) (идент. номер) и это поле никак не связано с Номером(реальным номером) накладной.

В таблице товар должно быть поле "НомерНакладной" или "InvoicesID"

Связь:
ID <- InvoiceID
один ко многим.

Далее есть смысл убрать из накладной столбцы с паспортными данными, и сформировать из них одну таблицу Attendants (сопровождающие):
ID, Фамилия, Имя, Отчество, Паспорт, Дата рождения.

В таблицу Накладные добавить AttendantID и связать его с ID из таблицы Attendants.

ID <- AttendatID

Или курсач или диплом делаете. Я таких сделал с сотню, опыт есть
Ответить с цитированием
  #4  
Старый 02.09.2013, 23:21
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Uniq!
Далее есть смысл убрать из накладной столбцы с паспортными данными, и сформировать из них одну таблицу Attendants (сопровождающие):
ID, Фамилия, Имя, Отчество, Паспорт, Дата рождения.

В таблицу Накладные добавить AttendantID и связать его с ID из таблицы Attendants.

ID <- AttendatID


Маленькая поправка. Это имеет смысл делать если экспедиторы свои или их много. Если экспедитор один и чужой, то можно и в самой накладной прописать. Хотя, если делать на вырост, то именно так.

ЗЫ. Это не наезд, а просто разъяснение новичку, что бы головой думал при проектировании БД, а только потом уже ваял. Ведь БД - это самая сложная для исправления часть (не в смысле, что ее поправить сложно, а в том, что правка БД ведет к огромному кол-ву правок клиентского, да порой и серверного, кода).
Ответить с цитированием
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
Uniq! (03.09.2013)
  #5  
Старый 03.09.2013, 00:34
Аватар для Uniq!
Uniq! Uniq! вне форума
Местный
 
Регистрация: 29.09.2010
Сообщения: 539
Версия Delphi: Delphi XE3
Репутация: 374
По умолчанию

Научники обычно просят ещё отвязать Машину от накладной и организовать прикрепление машины (т.е. номера, модели, марки, прицепа и т.д.) к сопровождающему (или водиле)

Зуб держу, это диплом ^_^
Ответить с цитированием
  #6  
Старый 03.09.2013, 06:10
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Uniq!
Научники обычно просят ещё отвязать Машину от накладной и организовать прикрепление машины (т.е. номера, модели, марки, прицепа и т.д.) к сопровождающему (или водиле)

Зуб держу, это диплом ^_^

Ну да. По правилам так и надо делать.
Просто в реальной жизни иногда имеет смысл следовать правилам, а иногда - нет. Если у фирмы/склада нет своего транспорта и его покупка не предвидится (самовывоз), то какой смысл заводить отдельную сущность, если можно считать, что она каждый раз новая (исключаем случай постоянных покупателей).
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 00:33.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter