Главная страница
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.038 c
3-83928
Ler
2003-06-03 13:57
2003.06.26
Вопрос по LocalSQL


3-83941
Stam
2003-05-23 10:26
2003.06.26
Ошибка при работе с Oracle - ORA-04031. Помогите...


1-84287
Hog
2003-06-14 23:24
2003.06.26
Перересовка отдельного окна.


1-84419
SSSSS
2003-06-06 22:58
2003.06.26
НАРОД!!! Как вывести форматированный текст поверх катртинки


3-83998
off
2003-05-27 06:43
2003.06.26
Считаем баланс?