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

Вниз

TIBTransaction.Commit - ?   Найти похожие ветки 

 
ghost_by ©   (2002-09-16 22:21) [0]

Объясните пожалуйста - зачем это нужно, и где и когда нужно вызывать? А то без вот этого самого Commita Blob поля не в какую не желают обновляться, хотя со всеми другими типами полей - все ОК...


 
-= Demon =-   (2002-09-17 10:36) [1]

Чтобы это понять, необходимо въехать, для чего нужны транзакции. А это такой механизм, который позволяет сохранить целостность БД и избежать возможных ошибок. Например, надо тебе провести какие-то изменения сразу с несколькими таблицами, причем эти изменения должны произойти именно СО ВСЕМИ таблицами. Т.е. если в 1-й и 2-й таблице все прошло нормально, а в 3-й произошла ошибка, то изменения из 1-й и 2-й должны быть удалены.
Все это позволяют сделать транзакции. Т.е. они ведут журнал всех произожедших изменений в БД и при необходимости могут вернуть старую информацию (провести откат).
Порядок работы следующий:
if IBTransaction.InTransaction then IBTransaction.Commit; // закрываем ранее открытую транзацию (если была, но это не есть гут)
IBTransaction.StartTransaction; // запускаем новую
// ... выполняем действия с БД .....
// если ошибка, то
IBTransaction.RollBack // производим откат
// иначе
IBTransaction.Commit; // закрываем транзакцию, подтверждая изменения.

Метод IBTransaction.StartTransaction нужно вызывать только если будут производится изменения в таблице (добавление, изменение, удаление). При выборке (SELECT) он не требуется...

Уффф! :)


 
Johnmen ©   (2002-09-17 10:57) [2]

Подкорректирую ответ...
1.IB не Oracle. Ведется не журнал, а версии записей...
2.И даже при SELECT стартовать тр-ию желательно, т.к. иначе она стартанет неявно...



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

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

Наверх




Память: 0.47 MB
Время: 0.021 c
1-21115
Faun
2002-09-25 13:11
2002.10.07
BreakPoint и BPL? Что случилось?


6-21180
Kapusto
2002-08-09 13:11
2002.10.07
Время на Novell-сервере


14-21209
skull
2002-09-11 12:29
2002.10.07
help me people!!


14-21270
Елена
2002-09-12 08:13
2002.10.07
Ошибки в Интернете


1-21107
exchoper
2002-09-20 14:17
2002.10.07
Информация по COM