Главная страница
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.022 c
2-1303719929
.code
2011-04-25 12:25
2011.07.31
объект в property


6-1240235052
kotyara
2009-04-20 17:44
2011.07.31
Скорость передачи строк через TTcpServer - TTcpClient


2-1302768161
DelphiN!
2011-04-14 12:02
2011.07.31
TSQL вычитание NULLa


3-1262005058
Вадим Хижинский
2009-12-28 15:57
2011.07.31
Изменения SQL запроса в FastReport


15-1302697009
Иксик
2011-04-13 16:16
2011.07.31
Gource