Главная страница
    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.44 MB
Время: 0.01 c
3-20901
Тормоз
2002-09-16 12:43
2002.10.07
Вопрос знатокам DOA


1-20994
Осирис
2002-09-26 12:28
2002.10.07
Наследование форм


6-21159
irq
2002-08-04 17:32
2002.10.07
ras


1-21117
kull
2002-09-25 16:29
2002.10.07
Ладно... тогда вопрос попроще...


1-20997
lovres
2002-09-26 17:04
2002.10.07
Как вертикально Caption на кнопку вывести?





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский