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

Вниз

Работа с БД в потоках   Найти похожие ветки 

 
altarasjuk ©   (2003-03-02 13:05) [0]

Доброго времени суток.
Есть TADOConnection. Есть 2 TADOQuery в разных потоках .Connection:= TADOConnection. и выполняется примерно такой код:

Поток1:

var
query1: TADOQuery;
begin
query1:= TADOQuery.Create(nil);
query1.Connection:= Bconnection; {Bconnection: TADOConnection}
query1.SQL.Add("Select * from ....");
query1.Active:= TRUE;
..............


Поток2:

var
query2: TADOQuery;
begin
query2:= TADOQuery.Create(nil);
query2.Connection:= Bconnection; {Bconnection: TADOConnection}
query2.SQL.Add("Select * from ....");
query2.Active:= TRUE;
..............

если выполняется тока один квери то всё ок, а если выполняются 2 одновременно, то получаю набор от Access Voilation до Invalid Pointer Operation, а бывает что асмовское окно (курсор на Push ...) и там валиться и отловить это фиг получается.
Может кто объяснит чё это твориться...
Зараннее благодарен.


 
Владислав ©   (2003-03-02 13:19) [1]

Так вроде в разных потоках Connection разные должны быть.


 
sniknik ©   (2003-03-02 13:21) [2]

добавь к каждому потоку Connection1:= TConnection.Create(nil); и т.д. (связь).

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

+
в начале выполнения процедуры потока делай CoInitialize(nil); в конце CoUnInitialize();



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

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

Наверх




Память: 0.47 MB
Время: 0.012 c
3-63963
Stas
2003-02-27 15:10
2003.03.20
Условие в запросе


1-64145
QUE
2003-03-07 12:29
2003.03.20
Как узнать состояние окна (Максимизировано, Минимизировано или )


6-64264
Boroda Oleg
2003-01-30 17:36
2003.03.20
Получить из Дельфи HTML-код выбранного сайта


1-64102
Андрусь
2003-03-05 14:57
2003.03.20
регулировка FindFirst/Next/Close


6-64254
bobersky
2003-01-29 10:48
2003.03.20
Работа с DialUp