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

Вниз

Мультинитиевое приложение для работы с БД   Найти похожие ветки 

 
Blade ©   (2002-05-18 11:50) [0]

В одной нити процедура A:

procudure a
begin
DB.StartTransaction;
// Тут что-то делаем с БД
DB.Commit;
end;


В другой - процедура B:

procedure b
begin
DB.StartTransaction;
// Тут что-то делаем с БД
DB.Commit;
end;


Вопрос:

Вот если процедура А завершит свои действия и выполнит Commit() в то время, как В еще будет работать, что произойдет с изменениями, сделанными процедурой В? Они тоже закоммитятся?
Подскажите, плиз, вариант решения. Буду признателен, если получу ответ на мыло, да еще и с примером.


 
Romkin ©   (2002-05-18 11:55) [1]

В разных нитях обязательно должны быть разные TSession & TDatabase (с разными именами), threadsafe только TSession.


 
Desdechado ©   (2002-05-18 12:10) [2]

если транзакции изменяют разные данные, не зависящие друг от друга, то наиболее вероятно, что обе они завершатся успешно.
в противном случае, позднее завершающаяся не пройдет.
это как работа разных приложений с одними данными



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

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

Наверх




Память: 0.47 MB
Время: 0.008 c
14-31009
VID
2002-05-05 00:54
2002.06.10
Рассинхронизация звука и изображения в mpeg-файлах.


3-30725
uncle_m16
2002-05-19 12:53
2002.06.10
Help_uncle_please


1-30825
Do the right thing
2002-05-31 15:25
2002.06.10
про shelllistview


1-30901
allrussia
2002-05-29 05:01
2002.06.10
Как ? 2 вопроса....


3-30726
ват
2002-05-18 16:26
2002.06.10
импорт таблицы EXCEL