Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.02.13;
Скачать: CL | DM;

Вниз

Как правильнее огрганизовать взаимодействие с базой из интерфейса   Найти похожие ветки 

 
Rostislav Rotaru ©   (2005-01-13 11:28) [0]

Здравствуйте. Пишется склад. В процессе работы, касаемо расходных документов, возник следующий вопрос: как правильнее написать модуль.
Есть таблицы MSSQL: t_products, t_documents, t_documents_details.
Соответственно, таблицы товаров, шапки документов, и позиции в документе. В t_documents_details хранится ссылка на id из t_products.
Есть форма. Я разделил ее на три части. Верхняя - шапка, слева - Список товаров с остатками (хранимая процедура sp_products), справа - сам документ (sp_documents_details). Пока сделал так: При выборе товара со списка слева, через AdoCommand делаю insert into t_documents_details.... ссылку на товар + остальное. Потом, делаю requery для sp_documents_details, чтобы обновить список позиций в документе. Во время обновления, через locate нахожу вновь добавленную позицию.
Вопрос: Правилен ли такой подход к организации этой части, и если нет, то какие еще могут быть варианты, учитывая большое количество документов (около 350-400 в день)и товаров в них (30-50).
Спасибо.


 
jiny   (2005-01-13 11:32) [1]

У меня тоже пишется складская программа, может вышлешь скриншоты по программе, обсудим в форуме механизм взаимодействия, поделимся идеями, я тебе вышлю свои скриншоты


 
Sergey13 ©   (2005-01-13 11:38) [2]

Ну например можно
1. при составлении нового документа писать не сразу в t_documents_details, а в ее аналог в памяти (типа RxMemoryData). После окончания ввода - одним махом записать в таблицу.
2. можно пользоваться не запросами напрямую, а через Insert/Append датасета. Съэкономишь на реквери.
3. =1+2 8-)


 
Ega23 ©   (2005-01-13 11:39) [3]

Мне нравится Master-Detail системы DBGrid"ов.


 
Rostislav Rotaru ©   (2005-01-13 11:46) [4]

Но насколько я знаю, не рекомендуется использовать гриды для редактирования (только для чтения). Отсюда проблема: в расходных вызываю отдельную форму <Введите количество>. А для приходных? Там же нужно указать цены...

Интересен подход Sergey13 ©   (13.01.05 11:38) [2]
Попробую.

jiny   (13.01.05 11:32) [1]
Скриншоты могу выслать... куда?


 
jiny   (2005-01-13 12:00) [5]

zhas-trz@tarazinfo.kz


 
Rostislav Rotaru ©   (2005-01-13 12:05) [6]

Sergey13 © (13.01.05 11:38) [2]
В принципе это соответствует последним рекоммендациям "не держать постоянно открытый набор данных". Не будет никаких камней потом?


 
Sergey13 ©   (2005-01-13 12:14) [7]

2[6] Rostislav Rotaru ©   (13.01.05 12:05)
Я не знаю, где ты черпаешь свои рекомендации, но предполагаю, что камни есть везде. Но это не значит, что их нельзя обойти.

Подсказка. Программ-Складов работает немеряно - это самая, ИМХО, многочисленная армия программ (кроме калькулятора ессно 8-). Значит сделать можно все. 8-)


 
Rostislav Rotaru ©   (2005-01-13 12:21) [8]

Sergey13 ©   (13.01.05 12:14) [7]
Естественно сделать можно все. Но хотелось бы чтобы все работало с наименьшими затратами ресурсов, быстро и стабильно. Поэтому спросил...
Я не имел ввиду камни при программировании, а потом, в процессе работы системы.

jiny   (13.01.05 11:32) [1]
Выслал...


 
Sergey13 ©   (2005-01-13 12:25) [9]

2[8] Rostislav Rotaru ©   (13.01.05 12:21)
>Я не имел ввиду камни при программировании, а потом, в процессе работы системы.
Что для тебя камни например? Каким из трех "моих" советов ты решил воспользоваться?


 
Rostislav Rotaru ©   (2005-01-13 12:27) [10]

Sergey13 ©   (13.01.05 12:25) [9]
Первая. Извините, забыл указать выше. Сейчас пробую, пока нравится...


 
Sergey13 ©   (2005-01-13 12:42) [11]

2[10] Rostislav Rotaru ©   (13.01.05 12:27)
>Первая
При этом может возникнуть только один (имхо) камень - за время составления документа остаток товара изменится и станет меньше передаваемого количества. Т.е. при записывании в БД 34 (например) значения из 50 возникнет ошибка. Твоя задача адекватно отреагировать на это - дать юзеру возможность заменить/исключить товар из документа. Т.е. не потерять весь документ.


 
Rostislav Rotaru ©   (2005-01-13 12:55) [12]

Это не проблема. Есть кнопка "Провести", и она в журнале документов. Спасибо.


 
jiny   (2005-01-13 13:53) [13]

Выслал скриншоты своей, извини за большой размер, некогда сжимать было



Страницы: 1 вся ветка

Текущий архив: 2005.02.13;
Скачать: CL | DM;

Наверх




Память: 0.5 MB
Время: 0.04 c
1-1106847291
rel_
2005-01-27 20:34
2005.02.13
Маркеры в TChart


3-1105958921
Shizuku
2005-01-17 13:48
2005.02.13
Вернуть результат из вычисляемого поля запроса


3-1105604278
Гаврила
2005-01-13 11:17
2005.02.13
Получения значения OUT параметра


1-1106552754
kingdom
2005-01-24 10:45
2005.02.13
Построение контура кривой Безье


1-1107174711
Aleksandr.
2005-01-31 15:31
2005.02.13
Почему у меня результат упаковки zLib ом не открывается Winzip?