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

Вниз

Что может вызывать блокирование записи?   Найти похожие ветки 

 
Aleksandr ©   (2002-11-26 16:37) [0]

Суть проблемы такова - поток создает TTable, присваивает ее DataBaseName путь к файлу таблицы, открывает, вставляет туда запись, сохраняет и уничтожает. Когда при следующем прохождении этого потока создаешь TTable, открываешь ее, находишь вставленную запись Locate, а потом пытаешься сделать ей Edit - БДЕ смертельно обижается и пишет, что record locked by another user. Она же была закрыта и - абсолютно точно - уничтожена, перед тем как пересоздаться заново... Может, тут что-то с сессией надо сделать?


 
Johnmen ©   (2002-11-26 17:07) [1]

Если сделать вставку в рамках единой транзакции - БДЕ, скорее всего, не будет обижаться :)))
Да и сессия д.б. одна...


 
Shaman ©   (2002-11-26 17:20) [2]

BDE кэширует таблицы и записывает их окончательно на диск только при закрытии сессии или при специальном вызове функции BDE API Как функция называется точно не помню, нашел ее в хелпе по BDE API


 
Aleksandr ©   (2002-11-26 17:29) [3]

Не совсем понял насчет единой транзакции - это же не SQL? Но все равно спасибо, счас попробую покопать... Странно, я полагал, что с закрытием таблицы все энти динамические сессии и датабазы, создаваемые бдей, сами закроются нафиг...


 
Romkin ©   (2002-11-26 17:48) [4]

Поток должен работать со своей TSession & TDatabase, и закрывать их по окончании работы (создавать эти компоненты надо в Execute, разумеется), а у TSession установить AutoSessionName - для этого и надо



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

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

Наверх




Память: 0.47 MB
Время: 0.014 c
4-52015
Lexa1900
2002-11-02 23:40
2002.12.16
Можно ли как-то сохранять все полученные hwnd?


1-51793
Крокус
2002-12-04 18:43
2002.12.16
удаленный доступ


1-51769
brestmarket
2002-12-04 13:56
2002.12.16
Как MainMenu заставить затенять редко используемые меню?


14-51882
Леший
2002-11-22 16:00
2002.12.16
Подскажите, ссылку, где есть лицензия на INTERBASE сервер


1-51686
avsh
2002-12-05 20:04
2002.12.16
TImage