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

Вниз

Многопоточность в приложениях баз данных...   Найти похожие ветки 

 
malefik ©   (2003-06-02 16:36) [0]

Есть база на Access ~100000 тысяч записей...
Пишем прогу которая из этой базы по ODBC забирает данные и кидает их в базу Interbase тоже по ODBC.....(не спрашиваете почему такой геморой .....уверяю так надо)....как лучше организовать работу приложения? (всмысле работа с потоками) что использовать? TThread? ( сама прога при работе тормозит безбожно)...????


 
passm ©   (2003-06-02 16:55) [1]

malefik © (02.06.03 16:36)> Наследуешь поток от TThread. Объявляешь свойства (FromDataSet: TDataSet, InsertQuery: TQuery). Можешь ссылку на Progressbar сделать... Перегружаешь TThread.Execute, чтобы пробежать по FromDataSet и выполнить InsertQuery на каждом шаге.
Но проблему с тормозами не решит. Это для удовольствия пользователя :)


 
needle ©   (2003-06-02 17:03) [2]

Будет у тебя эта обработка производится одним потоком, или несколькими, все равно выше 100% использования процессора не прыгнуть :-)
Вставку записей делай через SQL (insert into), это гораздо быстрее чем через Table.Insert, если есть компоненты визуализации (DBGrid, ВИДфиуд и прочь) отключи их -
DisableControls.
Вообще хорошая практика чтоб не создавалось видимости зависания приложения, внутри цикла вставить Application.ProcessMessages, тогда приложение будет перерисовывать свою форму и реагировать на мышу и клаву :-)


 
passm ©   (2003-06-02 17:13) [3]

Можно перекачку данных разбить на группы.
Например, в перекачиваемых данных есть некий код филиала. Делаешь выборку:
SELECT AF.ID, AF.NAME
FROM AFFILIATE AF
WHERE AF.ID IN (SELECT T1.AFFILIATE FROM TABLE1 T1)
Бежишь по этому запросу, пишешь пользователю "Обрабатываю данные по такому-то филиалу", открываешь основной запрос с выборкой по текущему филиалу и в Interbase.



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

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

Наверх




Память: 0.47 MB
Время: 0.016 c
8-84444
__ALX__
2003-03-10 23:58
2003.06.26
Dynamic Array


3-83862
NataliK
2003-06-02 11:35
2003.06.26
Подскажите алгоритм


6-84480
dimka
2003-04-21 13:18
2003.06.26
Две машины в своих локальных сетях есть прокси как организовать


1-84161
Aleksandr
2003-06-11 15:29
2003.06.26
Что надо сделать для


1-84160
Неплохой человек
2003-06-11 15:45
2003.06.26
Загрузка строк в объект типа TStringList - непонятные глюки