Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.10.07;
Скачать: [xml.tar.bz2];

Вниз

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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.009 c
14-21249
spROOT13
2002-09-12 21:55
2002.10.07
Звуки


4-21306
Алёшка
2002-08-19 14:07
2002.10.07
Перехват WM_KeyDown у TApplication


3-20883
(FZ)XupypG
2002-09-14 04:54
2002.10.07
Ошибка BDE


1-21097
Начинающий делфер
2002-09-25 12:33
2002.10.07
Как сделать окно непрямоугольной формы?


6-21172
Andrew2
2002-08-05 13:03
2002.10.07
Смена портов NMMsg и NMStrm





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский