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

Вниз

Обращение к БД InterBase из разных потоков   Найти похожие ветки 

 
prodex   (2011-04-25 09:36) [0]

Здравствуйте уважаемые Мастера.
Есть 2 потока, которые обращаются к одной БД через 1 связку IBDatabase, IBTransaction - это общие компоненты. Плюс ко всему этому 1 поток использует для модификации одной переменной одного поля и чтения записей IBTable, а другой поток - IBSQL для модификации группы переменных в одном поле. Есть ситуации когда генерируется ошибка "Acceess violation...". При просмотре CPU ошибка возникает в некой процедуре IBCustomDataset.InternalUpdates, в коде в это время вызывается IBTable.Last. Могу ли я добавить в IBDataBase.Transactions два IBTransaction и использовать их в разных потоках?


 
Сергей М. ©   (2011-04-25 10:09) [1]

Так делать недопустимо.
Каждый поток должен иметь свой собственный отдельный "комплект" объектов доступа к БД, начиная с IBDatabase. Эти требования вытекают из потоконебезопасности клиентской части СУБД (gds32.dll), не более чем API-"оболочкой" которой являются эти объекты доступа.


 
prodex   (2011-04-25 11:18) [2]

Спасибо за исчерывающий ответ. (НЕ сарказм). Теперь я знаю что делать.


 
OW ©   (2011-04-25 11:22) [3]


> Спасибо за исчерывающий ответ. (НЕ сарказм).


+1



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

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

Наверх




Память: 0.47 MB
Время: 0.007 c
1-1261057584
Baner
2009-12-17 16:46
2011.07.31
Delphi TFileStream Parser


11-1227416394
Валера
2008-11-23 07:59
2011.07.31
Проблема с скриншотом экрана


2-1303502928
istok
2011-04-23 00:08
2011.07.31
EndOfTheDay...


2-1303387044
stenfit
2011-04-21 15:57
2011.07.31
Incompatible types


15-1302090541
oxffff
2011-04-06 15:49
2011.07.31
AfterConstruction, beforedestruction у record