Главная страница
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.009 c
2-1303453840
JohnKorsh
2011-04-22 10:30
2011.07.31
Простой вопрос по использованию DLL.


15-1302772506
Дмитрий С
2011-04-14 13:15
2011.07.31
Какова вероятность, что два случайных числа равны.


8-1213608349
НаТаШа
2008-06-16 13:25
2011.07.31
Как использовать своё оформление ScrollBar TrackBar


1-1261051643
harisma
2009-12-17 15:07
2011.07.31
Название целевой директории в формате DOS


15-1300890864
Kerk
2011-03-23 17:34
2011.07.31
Посоветуйте eInk -читалку