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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #16  
Старый 26.05.2008, 13:58
KIA KIA вне форума
Прохожий
 
Регистрация: 15.05.2008
Сообщения: 21
Репутация: 10
По умолчанию

у меня не только эти две таблички, у меня ещё две нормализации.......одна из них - это id_работы и id_детали (какому виду работ какие детали необходимы), вторая нормализация - это id_заказа, id_работы и id_использавания (какие работы есть в заказе и какие детали используются, клиента или автосервиса)
Ответить с цитированием
  #17  
Старый 26.05.2008, 14:55
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,029
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

а тут тебя не интересует другие таблицы, за исключением основных.
Тут надо считать на корневых, в которых храняться именно строки заказа (бо как там указаны все интересующие тебя данные).

Как бы делал я.
Я бы сделал 2 основных таблички:
Orders - заголовки заказов,
OrderItems - строки заказов.

Естественно, в OrderItems есть поля:
OrderID - ид заказа
Itemtype - тип записи (деталь/работа)
JobID - ид работы
PartID - ид детали
ClientsPart - деталь клиента (флаг = [0,1])
Measure - ед. изм.
Quantity - кол-во
Cost - стоимость 1 шт
ItemSum - стоимость кол-ва (можно делать не физическим, а виртуальным).

Соответсвенно, в процессе работы заполняется таблица OrderItems.
Сумма по ней считается либо одним запросом (:OID - параметр ид заказа)

SELECT SUM(ItemSum) AS OrderSum WHERE OrderID = :OID And ClientsPart = 0

Или, если ItemSum виртуальное, то

SELECT SUM(Cost * Quantity) AS OrderSum WHERE OrderID = :OID And ClientsPart = 0

Если считаем внутри клиентского приложения - то так, как я писал в предыдущем посте, т.к. у тебя уже есть все позиции текущего заказа.

Кстати, запрос на вычисление суммы заказа в указанном выше виде можно воткнуть в триггер и просто заполнять поле таблички Orders.

Вот.

А как ты заполняешь собственно табличку позиций заказа никого не волнует. Фактически, пользователь может ввести как отдельные детали/работы, так и создать несколько записей при выборе какой-то предопределенной операции.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter