Главная страница
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.012 c
1-30876
Andrew22
2002-05-29 16:27
2002.06.10
Закрытие проги.


3-30696
Andr
2002-05-18 03:32
2002.06.10
BDE


14-30975
mimino
2002-05-06 21:13
2002.06.10
прошу простой помощи


3-30736
Dorosh
2002-05-17 11:33
2002.06.10
RxMemoryData.Filter


7-31033
ASM
2002-03-14 00:00
2002.06.10
Неужели есть способ?