Главная страница
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.018 c
1-30770
diMAN
2002-05-30 18:19
2002.06.10
Автоматизация ввода серии и номера паспорта


4-31036
Sirus
2002-04-06 11:35
2002.06.10
Проблема с выгрузкой формы в DLL из памяти


1-30799
Semion
2002-05-29 20:04
2002.06.10
Как заставить подлый TDateTimePicker выводить текст нужным цветом


14-30999
drpass
2002-05-07 21:18
2002.06.10
Гибернация в Win2000/XP


6-30944
Kerrik
2002-03-21 20:29
2002.06.10
Траффик под Win98