Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.03.20;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.008 c
1-64103
Vasechkin
2003-03-08 13:34
2003.03.20
Многопроцессная прога


8-64228
Eugenex
2002-12-05 11:56
2003.03.20
Стеганографирую


14-64357
Intell
2003-03-05 11:54
2003.03.20
Работа с WinRAR или WinZIP


1-64104
San
2003-03-05 16:50
2003.03.20
Variant && Srtring


1-64084
basile
2003-03-10 11:20
2003.03.20
Set





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский