Полезное для программистов:

Фриланс
Новости
Статьи
   
Рубрики:


Что такое транзакция ?

Поиск:
Транзакция - последовательность взаимосвязанных действий, рассматриваемое как единое целое.
Т.е. при открытии транзакцию,  предполагается что все последующие действия должы быть выполнены, либо не выполнено ни одно. Например тебе нужно в 10 базах изменить значение некоторого поля, причем это изменение должно быть выполнено либо для всех десяти, либо не выполнено совсем. Твои действия(пример для ADS и С++Builder)
Код
AdsConnection->BeginTransaction();//открытие транзакции
try
{
 AdsTable1->Edit();
 AdsTable1->FieldByName("abc")->AsString = "qwerty";
 AdsTable1->Post();
 ......
 AdsTable10->Edit();
 AdsTable10->FieldByName("zxc")->AsString = "jfhf";
 AdsTable10->Post();
 AdsConnection->Commit();//завершение транзакции
}
catch(...)
{
 // где-то сбой, откатываем транзакцию
 AdsConnection->RollBack();//откат транзакции
}

Если произойдет сбой, например, одну из записей будет невозможно отредактировать (заблокирована другим пользователем и т.д), выполниться откат и все предыдущие записи вернутся к первоначальному состоянию.
Таким образом с помощью транзакции обеспечивается логическая целостность данных в БД 

Автор: Vyacheslav
Автор: Vyacheslav






Просмотров: 7358

 

 

Новые статьи:


Популярные:
  1. Как сделать цикличным проигрывание MIDI-файла?
  2. Создание AVI файла из рисунков
  3. Как устройство "отключить в данной конфигурации"?
  4. Kто в данный момент присоединен через Сеть?
  5. Как узнать количество доступной памяти?
  6. Как реализовать в RichEdit разноцветный текст?
  7. Как скрыть свое приложение от ProcessViewer
  8. Как программно нажать/скрыть/показ кнопку "Start"?
  9. Модуль работы с ресурсами в PE файлах
10. Функции вызова диалоговых окон выбора
11. Проверка граматики средствами Word'а из Delphi.
12. Модуль для упрощенного вызова сообщений
13. Функции для записи и чтение своих данных в, ЕХЕ- файле
14. Рекурсивный просмотр директорий
15. Network Traffic Monitor
16. Разные модули
17. Универсальная функция для обращения к любым экспортируем функциям DLL
18. Библиотека от VladS
19. Протектор для UPX'а
20. Еще об ICQ, сообщения по контакт листу?
21. Использование открытых интерфейсов
22. Теория и практика использования RTTI
23. Работа с TApplication
24. Примеры использования Drag and Drop для различных визуальных компонентов
25. Что такое порт? Правила для работы с портами
26. Симфония на клавиатуре
27. Загрузка DLL
28. Исправление автоинкремента
29. Взаимодействие с чужими окнами
30. Проверить дубляжи в столбце


 

 

 
 
На главную