Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Объясните мне глупому что такое есть - Транзакция?

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Сети
Предыдущая тема :: Следующая тема  
Автор Сообщение
xt



Зарегистрирован: 17.12.2002
Сообщения: 557
Откуда: Донецк, UA

СообщениеДобавлено: Чт Апр 03 2003 15:54    Заголовок сообщения: Объясните мне глупому что такое есть - Транзакция? Ответить с цитатой

Объясните мне глупому что такое есть - Транзакция?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
FSerg
Гость





СообщениеДобавлено: Чт Апр 03 2003 17:48    Заголовок сообщения: Некая последовательность операций, которая должна быть либо целиком выполненя, либо не выполнена вообще. Ответить с цитатой

Например:
Запись в базе данных и изменение связанных с этим полем индексов.
Если изменить индексы после изменения базы не удалось, то нужно откатить базу и сообщить о невозможности выполнения операции. Иначе получим несоответствие базы и индексов - т.е. кранты.
Вернуться к началу
Dmitry.Karpov http://prof
Гость





СообщениеДобавлено: Чт Апр 03 2003 19:19    Заголовок сообщения: Транзакция - это набо элементарных операций, который д.б. доведен до конца или возвращен в исходное состояние, как будто ничего Ответить с цитатой

Рассмотрим ситуацию с перечислением некой суммы денег с одного банковскогосчета на другой. В компьютере это делается так:
- прочитать содержимое первого счета;
- вычесть из него сумму;
- записать новое значение счета;
- прочитать содержимое второго счета;
- прибавить к нему сумму;
- записать новое значение счета.
1) Что произойдет в случае выключения питания?
2) Что произойдет, если в момент между первой и третьей операцией (они происходят не одномоментно) кто-то захочет изменить содержимое первого счета?

Чтобы этого не случилось, операцию проводят в несколько этапов:
- Все используемые в транзакции данные помечаются как заблокированные. Если кто-то уже заблокировал их - ждем, когда разблокируются.
- Составляем задание, куда чего надо записать (т.е. вычисляем новые значения, но записываем их в другое место).
- После того, как задание записано на жеский диск, пишет признак того, что оно окончательно сформировано.
- Выполняем транзакцию, т.е. записываем новые значения.
- Разблокируем записи.
1) Если свет выключили до того, как признак завешенности задания был записан, транзакция срывается (не выполняется). Если же после, то транзакция доводится до конца.
2) В заблокированные записи никто не лазает.
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Сети Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...