Главная страница
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.04 c
8-84467
Intell
2003-03-05 14:19
2003.06.26
Как я могу получить картинку с видео источника?


14-84672
DenKop
2003-06-08 20:51
2003.06.26
Знатокам MSOffice, Word


3-84042
Grey_g
2003-06-01 14:10
2003.06.26
Error


1-84257
zolotov
2003-06-12 12:20
2003.06.26
Customize ToolBar


4-84841
fifo
2003-04-22 18:10
2003.06.26
Как захватить изображене чужого окна?