Главная страница
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
15-1302559355
Германн
2011-04-12 02:02
2011.07.31
InnoSetup переменная {app}


11-1236071712
rvi
2009-03-03 12:15
2011.07.31
Запись в log


2-1303835617
Vasja123
2011-04-26 20:33
2011.07.31
Как сделать OnClick на Label если Enabled=false


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


2-1303720303
MsFoxy
2011-04-25 12:31
2011.07.31
приложение в делфи на подобии 1с