Главная страница
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.017 c
1-84411
Гость необразованный
2003-06-09 18:51
2003.06.26
иконка на кнопке


11-84055
SPeller
2002-10-10 14:37
2003.06.26
Динамическое создание/удаление контролов.


1-84167
Кот
2003-06-08 12:58
2003.06.26
картинки


4-84814
1g0r
2003-04-22 13:53
2003.06.26
глубина цвета в HBITMAP, созданной CreateCompatibleBitmap()


14-84655
PaulSin
2003-06-10 13:18
2003.06.26
Сабж - значение слова ?