Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Транзакции и блокировки

Содержание

34. Определение транзакции. Свойства транзакций. Успешное завершение и откат транзакций. Операторы Transact SQL для работы с транзакциями. Контрольные точки.
Транзакции и блокировки 34. Определение транзакции. Свойства транзакций. Успешное завершение и откат транзакций. Операторы Transact Понятие транзакцииПри работе с базами данных не исключены ошибки и сбои. Они С помощью транзакций и блокировок обеспечивается согласованность и целостность данных, несмотря на возникающие в системе ошибки. Транзакцией называется последовательность операций, производимых над базой данных и переводящих ее из Примером транзакции может быть перевод денег через банкомат. Сумма 100 т.р. переводится Пример транзакции по вводу данных о вновь поступивших в библиотеку книгах. Эту Транзакция – это неделимая, с точки зрения воздействия на базу данных, последовательность Существуют различные модели транзакций, которые могут быть классифицированы на основе различных свойств, Классические транзакции характеризуются классическими свойствами: Неразрывности (атомарности), согласованности, изолированности, долговечности. Свойство атомарности выражается в том, что транзакция должна быть выполнена в Свойство изолированности означает, что конкурирующие за доступ к БД транзакции физически обрабатываются В многопользовательских системах с одной базой данных одновременно может работать несколько пользователей Свойство долговечности означает, что если транзакция завершена успешно, то те изменения данных, 2 варианта завершения транзакции: Если все операторы выполнены успешно и в процессе 2. Если в процессе выполнения транзакции произошёл сбой, БД должна быть возвращена Режимы транзакций.Операторы Transact SQL для работы с транзакциями. Явные транзакции После завершения транзакции вся информация о произведенных изменениях хранится либо в специально В соответствии со стандартом языка SQL:1999 транзакции могут образовываться явным образом с Явная транзакция — это транзакция, начало и конец которой определены явно.В стандарте Оператор COMMIT означает успешное завершение транзакции, результаты транзакции фиксируются во внешней памяти. В расширенной модели транзакций (например, в СУБД SQL SERVER) предусмотрены следующие операции: оператор SAVE TRANSACTION создаёт внутри транзакции точку сохранения, которая соответствует промежуточному состоянию Оператор ROLLBACK имеет 2 модификации. Если он используется без дополнительного параметра, то Точки сохранения целесообразно использовать в длинных и сложных транзакциях, чтобы обеспечить возможность Не рекомендуется организовывать работу так, чтобы транзакции содержали много команд, тем более BEGIN TRANSACTIONINSERT INTO Студенты VALUES(2005,'Иванов',NULL,NULL,NULL,NULL,1,NULL) UPDATE оценки SET код_студента=2005 WHERE код_студента =2009DELETE Триггер выполняется как неявно определённая транзакция, поэтому внутри триггера допускается применение команд BEGIN TRAN16.1. Использование точек сохраненияВ точке point1 сохраняется первоначальное состояние таблицы ТоварBEGIN Транзакциям могут быть присвоены имена. В этом случае команда сообщающая о начале Неявный режим В неявном режиме транзакция автоматически начинается при использовании определённых операторов Чтобы задать неявный режим транзакций, используется оператор:  SET IMPLICIT_TRANSACTIONS {ON | Поскольку здесь не используется явная инструкция BEGIN TRANSACTION, легко забыть о необходимости Транзакции с автоматической фиксациейРежим автоматической фиксации транзакций является режимом управления транзакциями SQL Когда SQL Server использует транзакции с автофиксацией, каждая инструкция рассматривается как транзакция. Пример транзакции: BEGIN TRAN UPDATE account SET balance= balance- 100 WHERE account_number=@s Вложенные транзакцииВложенными называются транзакции, выполнение которых инициируется из тела уже активной транзакции.Для Если команда ROLLBACK TRANSACTION используется на любом уровне вложенности без указания имени Транзакционность поддерживается следующими архитектурными компонентами SQL Server: журналами транзакций, механизмом управления параллельным выполнением, блокировками. 35. Журнал транзакцийРеализация принципа подтверждения или отката транзакций обеспечивается специальным механизмом, для Журнал транзакций содержит последовательность записей об изменении БД. Он предназначен для обеспечения Информация, записывающаяся в журнал транзакций, включает:  Время начала каждой транзакции; Целью журнализации изменений баз данных является обеспечение возможности восстановления согласованного состояния базы данных после любого сбоя. Общие принципы журнализации и восстановления:результаты зафиксированных транзакций должны быть сохранены в восстановленном Возможны следующие ситуации, при которых требуется производить восстановление состояния БД:Восстановление после внезапной Восстановление после поломки основного внешнего носителя БД (жесткий сбой). При мягком сбое необходимо восстановить содержимое БД по содержимому журналов транзакций, хранящихся Для большей надежности журнал транзакций часто дублируется системными средствами СУБД, именно поэтому Имеется 2 варианта ведения журнала транзакций: протокол с отложенными обновлениями; протокол с      Когда транзакция Т1 начинается, в протокол заносится запись Альтернативный механизм с немедленным выполнением предусматривает внесение изменений сразу в БД, а Для восстановления при сбое используется следующий механизм: Если транзакция содержит команду начала На самом деле восстановление происходит по более сложным алгоритмам, т.к. изменения, как Основным принципом согласованной политики выталкивания буфера журнала и буферов страниц базы данных Если во внешней памяти базы данных находится некоторый объект базы данных, по UPDATE Table SET c1 = 10 WHERE c2 LIKE '%Иванов%';Выполняются следующие операции. Параллельная работа пользователей. Проблемы параллельного выполнения: потерянное обновление, доступ к промежуточным результатам транзакции, строки-фантомы. Когда множество пользователей одновременно пытаются модифицировать данные в БД, необходимо создать систему Управление блокировкамиС помощью блокировок обеспечиваетcя целостность и согласованность БД при параллельной работе. Проблемы параллельного выполненияЕсли несколько пользователей одновременно обращаются к БД при отсутствии блокировок, •потерянные обновления;•чтение незафиксированных данных ;•несогласованный анализ (неповторяемое чтение);•чтение фантомов. Потерянные обновленияПотерянные обновления появляются при выборе одной строки двумя или более транзакциями, Например, два редактора сделали копии одного и того же документа. Затем внесли Чтение незафиксированных данных (“грязное” чтение)Чтение незафиксированных данных возникает, когда вторая транзакция читает В транзакции 1 изменяется значение поля f2, а затем в транзакции 2 Несогласованный анализ (неповторяемое чтение)Несогласованным анализом называется ситуация, когда вторая транзакция несколько раз :В транзакции 2 выбирается значение поля f2, затем в транзакции 1 изменяется Чтение фантомовТак называется ситуация, когда строки из диапазона строк, читаемого во время В транзакции 2 выполняется SQL-оператор, использующий все значения поля f2. Затем в Типы конфликтов между двумя параллельными транзакциями:· W-W – транзакция 2 пытается изменить объект, 37. Определение блокировки. Управление блокировками в SQL Server. Оптимистические и пессимистические стратегии блокировки. Блокируемые ресурсы. Блокировкой называется временное ограничение на выполнение некоторых операций обработки данных.Управлением блокировками на Транзакции и блокировки тесно связаны друг с другом. Транзакции накладывают блокировки на SQL Server поддерживает как оптимистическое, так и пессимистическое управление параллельным выполнением. По Оптимистическое параллельное выполнениеПри оптимистическом управлении параллельным выполнением предполагается, что конфликты из-за ресурсов Пессимистическое параллельное выполнениеПессимистическое управление параллельным выполнением блокирует ресурсы, затребованные транзакцией, чтобы обеспечить 38. Уровни изоляции транзакций. Сериализуемые транзакции. Уровни изоляции «повторяемое чтение», «завершенное чтение», Уровни изоляцииПроблемы, связанные с параллельным выполнением, разрешают, используя уровни изоляции (ISOLATION LEVEL). Уровни изоляции обеспечивают правила параллелизма и последовательности работы с данными. Когда устанавливается Уровни изоляции в стандарте SOL-99Уровень изоляции определяет степень изоляции одной транзакции от Стандарт SQL-99 определяет следующие уровни изоляции•неподтверждаемое чтение READ UNCOMMITTED (чтение незафиксированных данных)—самый •подтверждаемое чтение Read committed - чтение, при котором отсутствует черновое, •повторяемое чтение (Repeatable read) - Уровень, при котором чтение одной и той •упорядочение (Serializable) —наивысший уровень, на котором транзакции полностью изолированы друг от друга.На транзакции не могут считывать данные, которые были изменены другими транзакциями, но Блокировки диапазона сохраняются до завершения транзакции. Это самый строгий уровень изоляции, поскольку По умолчанию, устанавливается изоляция Read Committed. Основной принцип состоит в том, что Тривиальным решением является действительно последовательное выполнение транзакций. Но существуют ситуации, в которых Блокировки, называемые также синхронизационными захватами объектов, могут быть применены к разному типу В ряде СУБД реализована блокировка на уровне страниц. В этом случае СУБД Настройка блокировокSQL Server реализует блокирование автоматически, но в приложениях эту функцию можно Обработка взаимоблокировокВзаимоблокировка возникает, когда два или более потоков, конкурирующих за ресурс, становятся взаимозависимыми. Взаимоблокировка возникает, когда у каждой транзакции заблокирован ресурс, который пытаются заблокировать другие Так как ни одна из задач не может продолжиться до тех пор, Обе транзакции находятся в состоянии взаимоблокировки и будут всегда находиться в состоянии Минимизация числа взаимоблокировокХотя полностью избежать взаимоблокировок не удаётся, их число можно существенно Чтобы минимизировать число взаимоблокировок, необходимо придерживаться следующих правил:•следить, чтобы транзакции были короткими Оператор SET LOCK_TIMEOUT позволяет задать максимальный период ожидания оператором освобождения ресурса. Если В приложении должен быть обработчик ошибок, перехватывающий сообщение об ошибке 1222. Реализация Основными режимами блокировок являются следующие: совместный режим – S (Shared), означающий совместную Настройка уровней изоляции транзакцииПо умолчанию SQL Server работает на уровне изоляции READ В некоторых СУБД возможна блокировка на уровне строк. MS SQL Server стремится Реализация указаний блокирования на уровне таблицыДля операторов SELECT, INSERT, UPDATE и DELETE NOLOCK - можно читать неподтверждённые транзакции. PAGLOCK - блокировка страницы.ROWLOCK - блокировка В следующем примере установлен уровень изоляции транзакций SERIALIZABLE, а также используется указание При одновременном обращении нескольких пользователей к БД, когда блокирование не применяется, весьма Возможно оптимистическое и пессимистическое управление параллельным выполнением. При оптимистическом управлении параллельным выполнением Уровень изоляции —это степень, в которой одна транзакция должна быть изолирована от Программирование эффективных транзакцийСледует создавать как можно более короткие транзакции. При модификации данных
Слайды презентации

Слайд 2
34. Определение транзакции. Свойства транзакций. Успешное завершение и

34. Определение транзакции. Свойства транзакций. Успешное завершение и откат транзакций. Операторы

откат транзакций. Операторы Transact SQL для работы с транзакциями.

Контрольные точки.



Слайд 3 Понятие транзакции
При работе с базами данных не исключены

Понятие транзакцииПри работе с базами данных не исключены ошибки и сбои.

ошибки и сбои. Они могут быть вызваны ошибками пользователей,

взаимодействующих с СУБД, или неустойчивой работой компьютеров. Поэтому в СУБД применяют специальные способы отмены действий, вызвавших такие ошибки.




Слайд 4
С помощью транзакций и блокировок обеспечивается согласованность и

С помощью транзакций и блокировок обеспечивается согласованность и целостность данных, несмотря на возникающие в системе ошибки.

целостность данных, несмотря на возникающие в системе ошибки.


Слайд 5 Транзакцией называется последовательность операций, производимых над базой данных

Транзакцией называется последовательность операций, производимых над базой данных и переводящих ее

и переводящих ее из одного непротиворечивого состояния в другое

непротиворечивое состояние.



Слайд 6 Примером транзакции может быть перевод денег через банкомат.

Примером транзакции может быть перевод денег через банкомат. Сумма 100 т.р.



Сумма 100 т.р. переводится с одного счета на другой.

Программа вычитает сумму с первого счета, после чего прибавляет ее ко второму. Во время работы программы после выполнения первой модификации может произойти сбой питания, и увеличение второго счета не произойдёт.

Для того чтобы избежать подобной ситуации обе команды должны быть объединены в транзакцию. В случае, когда все команды транзакции не выполняются, происходит откат транзакции.



Слайд 7 Пример транзакции по вводу данных о вновь поступивших

Пример транзакции по вводу данных о вновь поступивших в библиотеку книгах.

в библиотеку книгах.

Эту операцию можно разбить на 2

последовательные: сначала ввод данных о книге – это новая строка в таблице Книги. Затем необходимо ввести данные обо всех экземплярах книги - это ввод набора новых строк в таблицу Экземпляры. Если эта последовательность действий будет прервана, то база данных не будет соответствовать реальному объекту, поэтому желательно выполнять ее как единую работу над базой данных.



Слайд 8 Транзакция – это неделимая, с точки зрения воздействия

Транзакция – это неделимая, с точки зрения воздействия на базу данных,

на базу данных, последовательность операций манипулирования данными.

Транзакции позволяют

обработать набор операторов Transact-SQL как единое целое.



Слайд 9 Существуют различные модели транзакций, которые могут быть классифицированы

Существуют различные модели транзакций, которые могут быть классифицированы на основе различных

на основе различных свойств, включающих структуру транзакции, параллельность внутри

транзакции, продолжительность и т.д.



Слайд 10 Классические транзакции характеризуются классическими свойствами:

Неразрывности (атомарности),
согласованности,

Классические транзакции характеризуются классическими свойствами: Неразрывности (атомарности), согласованности, изолированности, долговечности.


изолированности,
долговечности.


Слайд 11 Свойство атомарности выражается в том, что транзакция

Свойство атомарности выражается в том, что транзакция должна быть выполнена

должна быть выполнена в целом или не выполнена вовсе

(“Все или ничего”).

Свойство согласованности гарантирует, что по мере выполнения транзакции данные переходят из одного согласованного состояния в другое согласованное состояние - транзакция не разрушает взаимной согласованности данных.



Слайд 12 Свойство изолированности означает, что конкурирующие за доступ к

Свойство изолированности означает, что конкурирующие за доступ к БД транзакции физически

БД транзакции физически обрабатываются последовательно, изолированно друг от друга,

но для пользователей это выглядит так, как будто они выполняются параллельно.



Слайд 13
В многопользовательских системах с одной базой данных одновременно

В многопользовательских системах с одной базой данных одновременно может работать несколько

может работать несколько пользователей или прикладных программ.

Задачей системы

является обеспечение изолированности пользователей, т.е. создание достоверной и надёжной иллюзии того, что каждый из пользователей работает с базой данных в одиночку.



Слайд 14 Свойство долговечности означает, что если транзакция завершена успешно,

Свойство долговечности означает, что если транзакция завершена успешно, то те изменения

то те изменения данных, которые были ею произведены, не

могут быть потеряны ни при каких обстоятельствах, даже в случае последующих ошибок.

Эти свойства (атомарность, согласованность, изоляция и устойчивость) называются ACID-свойствами (от англ, atomicity, consistency, isolation, durability).



Слайд 15 2 варианта завершения транзакции:

Если все операторы выполнены

2 варианта завершения транзакции: Если все операторы выполнены успешно и в

успешно и в процессе транзакции не произошло никаких сбоев

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

Фиксация транзакции означает, что все результаты выполнения транзакции становятся постоянными и станут видимы другим транзакциям только после того, как текущая транзакция будет зафиксирована.



Слайд 16
2. Если в процессе выполнения транзакции произошёл сбой,

2. Если в процессе выполнения транзакции произошёл сбой, БД должна быть

БД должна быть возвращена в исходное состояние.

Откат транзакции

– это действие, обеспечивающее аннулирование всех изменений данных, которые были сделаны операторами SQL в теле текущей незавершённой транзакции.

Слайд 17 Режимы транзакций.
Операторы Transact SQL для работы с транзакциями.

Режимы транзакций.Операторы Transact SQL для работы с транзакциями. Явные транзакции

Явные транзакции


Слайд 18
После завершения транзакции вся информация о произведенных изменениях

После завершения транзакции вся информация о произведенных изменениях хранится либо в

хранится либо в специально выделенной оперативной памяти, либо во

временной области отката в самой базе данных до тех пор, пока не будет выполнена одна из команд управления транзакциями.
Затем все изменения или фиксируются в базе данных, или отбрасываются, а временная область отката освобождается.

Слайд 20
В соответствии со стандартом языка SQL:1999 транзакции могут

В соответствии со стандартом языка SQL:1999 транзакции могут образовываться явным образом

образовываться явным образом с использованием оператора START TRANSACTION, либо

неявно, когда выполняется оператор, для которого требуется контекст транзакции. Например, операторы SELECT, UPDATE или CREATE TABLE могут выполняться только в контексте транзакции.

Слайд 21 Явная транзакция — это транзакция, начало и конец

Явная транзакция — это транзакция, начало и конец которой определены явно.В

которой определены явно.

В стандарте SQL99 определены операторы
START TRANSACTION,


СOMMIT,
ROLLBACK.



Слайд 22
Оператор COMMIT означает успешное завершение транзакции, результаты транзакции

Оператор COMMIT означает успешное завершение транзакции, результаты транзакции фиксируются во внешней

фиксируются во внешней памяти.
При завершении транзакции оператором ROLLBACK

результаты транзакции отменяются.

Слайд 23 В расширенной модели транзакций (например, в СУБД SQL

В расширенной модели транзакций (например, в СУБД SQL SERVER) предусмотрены следующие

SERVER) предусмотрены следующие операции:

оператор BEGIN TRANSACTION сообщает о

начале транзакции;

оператор COMMIT TRANSACTION сообщает об успешном завершении транзакции. Этот оператор, также как и COMMIT в модели стандарта, фиксирует все изменения, которые производились в БД в процессе выполнения транзакции;

·



Слайд 24
оператор SAVE TRANSACTION создаёт внутри транзакции точку сохранения,

оператор SAVE TRANSACTION создаёт внутри транзакции точку сохранения, которая соответствует промежуточному

которая соответствует промежуточному состоянию БД, сохранённому на момент выполнения

этого оператора.

В операторе SAVE TRANSACTION может стоять имя точки сохранения, поэтому в ходе выполнения транзакции может быть запомнено несколько точек сохранения соответствующих нескольким промежуточным состояниям.

Слайд 25 Оператор ROLLBACK имеет 2 модификации.

Если он используется

Оператор ROLLBACK имеет 2 модификации. Если он используется без дополнительного параметра,

без дополнительного параметра, то он интерпретируется как оператор отката

всей транзакции, если же он имеет параметр

ROLLBACK TO SAVEPOINT n,

то он интерпретируется как оператор частичного отката транзакции в точку сохранения n.




Слайд 26
Точки сохранения целесообразно использовать в длинных и сложных

Точки сохранения целесообразно использовать в длинных и сложных транзакциях, чтобы обеспечить

транзакциях, чтобы обеспечить возможность отмены изменений, выполненных определёнными операторами.


Слайд 27 Не рекомендуется организовывать работу так, чтобы транзакции содержали

Не рекомендуется организовывать работу так, чтобы транзакции содержали много команд, тем

много команд, тем более не связанных между собой.
Это

может привести к тому, что при отмене изменений будет выполнено слишком много действий, в том числе и тех, которые являются нужными и ошибки не вызвали.


Лучший вариант, когда транзакция состоит из одной команды или нескольких тесно связанных команд.



Слайд 28
BEGIN TRANSACTION
INSERT INTO Студенты VALUES(2005,'Иванов',NULL,NULL,NULL,NULL,1,NULL)
UPDATE оценки SET

BEGIN TRANSACTIONINSERT INTO Студенты VALUES(2005,'Иванов',NULL,NULL,NULL,NULL,1,NULL) UPDATE оценки SET код_студента=2005 WHERE код_студента

код_студента=2005 WHERE код_студента =2009
DELETE FROM Студенты WHERE код_студента=2009
IF @@ERROR

= 0
COMMIT
ELSE
ROLLBACK

Слайд 29 Триггер выполняется как неявно определённая транзакция, поэтому внутри

Триггер выполняется как неявно определённая транзакция, поэтому внутри триггера допускается применение

триггера допускается применение команд управления транзакциями (ROLLBACK TRANSACTION, COMMIT

TRANSACTION).




Слайд 30


BEGIN TRAN

16.1. Использование точек сохранения

В точке point1 сохраняется

BEGIN TRAN16.1. Использование точек сохраненияВ точке point1 сохраняется первоначальное состояние таблицы

первоначальное состояние таблицы Товар
BEGIN TRAN


DELETE FROM Товар WHERE КодТовара=2
SAVE

TRANSACTION point2

В точке point2 сохраняется состояние таблицы Товар без товаров с кодом 2.

DELETE FROM Товар WHERE КодТовара=3
SAVE TRANSACTION point3

В точке point3 сохраняется состояние таблицы Товар без товаров с кодом 2 и с кодом 3.

DELETE FROM Товар WHERE КодТовара<>1
ROLLBACK TRANSACTION point3

Происходит возврат в состояние таблицы без товаров с кодами 2 и 3, отменяется последнее удаление.

SELECT * FROM Товар

Оператор SELECT покажет таблицу Товар без товаров с кодами 2 и 3.

ROLLBACK TRANSACTION point1

Происходит возврат в первоначальное состояние таблицы.

Слайд 31
Транзакциям могут быть присвоены имена. В этом случае

Транзакциям могут быть присвоены имена. В этом случае команда сообщающая о

команда сообщающая о начале транзакции имеет вид BEGIN TRANSACTION

транзакции>

Слайд 32
Неявный режим
В неявном режиме транзакция автоматически начинается при

Неявный режим В неявном режиме транзакция автоматически начинается при использовании определённых

использовании определённых операторов T-SQL и продолжается, пока не появится

оператор явного окончания COMMIT или ROLLBACK.
ALTER TABLE CREATE TABLE DELETE DROP FETCH GRANT INSERT OPEN REVOKE SELECT TRUNCATE TABLE UPDATE


Слайд 33
Чтобы задать неявный режим транзакций, используется оператор: SET IMPLICIT_TRANSACTIONS

Чтобы задать неявный режим транзакций, используется оператор: SET IMPLICIT_TRANSACTIONS {ON |

{ON | OFF} Значение ON активизирует неявный режим, и OFF

отключает его. После отключения неявного режима используется режим автофиксации.

Слайд 34
Поскольку здесь не используется явная инструкция BEGIN TRANSACTION,

Поскольку здесь не используется явная инструкция BEGIN TRANSACTION, легко забыть о

легко забыть о необходимости фиксации или отката транзакции, что

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

Слайд 35 Транзакции с автоматической фиксацией

Режим автоматической фиксации транзакций является

Транзакции с автоматической фиксациейРежим автоматической фиксации транзакций является режимом управления транзакциями

режимом управления транзакциями SQL Server по умолчанию.

В этом

режиме каждый завершенный оператор Transact SQL либо фиксируется, либо откатывается. Если оператор выполнен успешно, он фиксируется, если при его исполнении возникла ошибка, выполняется откат.



Слайд 36
Когда SQL Server использует транзакции с автофиксацией, каждая

Когда SQL Server использует транзакции с автофиксацией, каждая инструкция рассматривается как

инструкция рассматривается как транзакция.
Если одна инструкция генерирует ошибку,

соответствующая ей транзакция автоматически подвергается откату. Если инструкция успешно и без ошибок выполняется, то транзакция автоматически фиксируется. Например, инструкции 1 и 3 пакета могут быть зафиксированы, а инструкция 2, вызвавшая ошибку, отменена.

Пакетное выполнение не определяет, следует ли обрабатывать все инструкции в пакете как единую транзакцию.

Слайд 38 Пример транзакции:

BEGIN TRAN
UPDATE account
SET balance=

Пример транзакции: BEGIN TRAN UPDATE account SET balance= balance- 100 WHERE

balance- 100
WHERE account_number=@s
If @‍@ error0
BEGIN
ROLLBACK

TRAN
RETURN
END
UPDATE card_account
SET balance=balance+100
WHERE account_number=@s
If @@ error<>0
BEGIN
ROLLBACK TRAN
RETURN
END
COMMIT TRAN



Слайд 39
Вложенные транзакции

Вложенными называются транзакции, выполнение которых инициируется из

Вложенные транзакцииВложенными называются транзакции, выполнение которых инициируется из тела уже активной

тела уже активной транзакции.
Для создания вложенной транзакции пользователю не

нужны какие-либо дополнительные команды. Он просто начинает новую транзакцию, не закрыв предыдущую. Завершение транзакции верхнего уровня откладывается до завершения вложенных транзакций.

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

Только когда все транзакции на всех уровнях завершены успешно, происходит фиксация всех сделанных изменений в результате успешного завершения транзакции верхнего уровня.

Слайд 40
Если команда ROLLBACK TRANSACTION используется на любом уровне

Если команда ROLLBACK TRANSACTION используется на любом уровне вложенности без указания

вложенности без указания имени транзакции, то откатываются все вложенные

транзакции, включая транзакцию самого высокого (верхнего) уровня.

В команде ROLLBACK TRANSACTION разрешается указывать только имя самой верхней транзакции. Имена любых вложенных транзакций игнорируются, и попытка их указания приведет к ошибке. Таким образом, при откате транзакции любого уровня вложенности всегда происходит откат всех транзакций.


Если же требуется откатить лишь часть транзакций, можно использовать команду SAVE TRANSACTION , с помощью которой создается точка сохранения.

Слайд 41 Транзакционность поддерживается следующими архитектурными компонентами SQL Server:
журналами

Транзакционность поддерживается следующими архитектурными компонентами SQL Server: журналами транзакций, механизмом управления параллельным выполнением, блокировками.

транзакций,
механизмом управления параллельным выполнением,
блокировками.



Слайд 42 35. Журнал транзакций

Реализация принципа подтверждения или отката транзакций

35. Журнал транзакцийРеализация принципа подтверждения или отката транзакций обеспечивается специальным механизмом,

обеспечивается специальным механизмом, для поддержки которого создана системная структура,

называемая журналом транзакций.

.



Слайд 43
Журнал транзакций содержит последовательность записей об изменении БД.

Журнал транзакций содержит последовательность записей об изменении БД. Он предназначен для

Он предназначен для обеспечения надёжного хранения данных в БД.




Слайд 44
Информация, записывающаяся в журнал транзакций, включает:

Время

Информация, записывающаяся в журнал транзакций, включает: Время начала каждой транзакции; Изменения

начала каждой транзакции;

Изменения внутри каждой транзакции;

Информация о

фиксации или откате каждой транзакции.

Слайд 45
Целью журнализации изменений баз данных является обеспечение возможности

Целью журнализации изменений баз данных является обеспечение возможности восстановления согласованного состояния базы данных после любого сбоя.

восстановления согласованного состояния базы данных после любого сбоя.


Слайд 46 Общие принципы журнализации и восстановления:
результаты зафиксированных транзакций должны

Общие принципы журнализации и восстановления:результаты зафиксированных транзакций должны быть сохранены в

быть сохранены в восстановленном состоянии БД, т.е. должно поддерживаться

свойство долговечности транзакций);

результаты незафиксированных транзакций не должны присутствовать в восстановленном состоянии БД.

Это означает, что восстанавливается последнее по времени согласованное состояние БД.



Слайд 47 Возможны следующие ситуации, при которых требуется производить восстановление

Возможны следующие ситуации, при которых требуется производить восстановление состояния БД:Восстановление после

состояния БД:
Восстановление после внезапной потери содержимого оперативной памяти (мягкий

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



Слайд 48
Восстановление после поломки основного внешнего носителя БД (жесткий

Восстановление после поломки основного внешнего носителя БД (жесткий сбой).

сбой).


Слайд 49
При мягком сбое необходимо восстановить содержимое БД по

При мягком сбое необходимо восстановить содержимое БД по содержимому журналов транзакций,

содержимому журналов транзакций, хранящихся на дисках.

При жёстком

сбое необходимо восстановить содержимое БД по архивным копиям и журналам транзакций.



Слайд 50 Для большей надежности журнал транзакций часто дублируется системными

Для большей надежности журнал транзакций часто дублируется системными средствами СУБД, именно

средствами СУБД, именно поэтому объем внешней памяти во много

раз превышает реальный объем данных в базе.



Слайд 51 Имеется 2 варианта ведения журнала транзакций:

протокол с

Имеется 2 варианта ведения журнала транзакций: протокол с отложенными обновлениями; протокол

отложенными обновлениями;
протокол с немедленными обновлениями.

Ведение журнала по принципу

отложенных обновлений предполагает следующий механизм выполнения транзакций:



Слайд 52      Когда транзакция Т1 начинается, в протокол заносится

     Когда транзакция Т1 начинается, в протокол заносится запись

запись Т1 Begin Transaction
  

На протяжении выполнения транзакции в протоколе для каждой изменяемой записи записывается новое значение
Т 1.ID_RECORD, атрибут, новое значение
  Если все действия, из которых состоит транзакция, успешно выполнены, в протокол заносится:
T1 COMMIT
Записи протокола, относящиеся к Т1, используются для внесения изменений в БД.
   Если происходит сбой, то СУБД просматривает протокол и выясняет, какие транзакции необходимо переделать. Транзакцию Т1 необходимо переделать, если протокол содержит обе записи Т1 Begin Transaction и T1 COMMIT. БД может находиться в несогласованном состоянии, однако все новые значения измененных элементов данных содержатся в протоколе, и это требует повторного выполнения транзакции. Для этого используется системная процедура REDO(), которая заменяет все значения элементов данных на новые, просматривая протокол в прямом порядке.
   Если в протоколе не содержится команда фиксации транзакции СOMMIT, то никаких действий проводить не требуется, а транзакция запускается заново.  



Слайд 53 Альтернативный механизм с немедленным выполнением предусматривает внесение изменений

Альтернативный механизм с немедленным выполнением предусматривает внесение изменений сразу в БД,

сразу в БД, а в протокол заносятся не только

новые, но и все старые значения изменяемых атрибутов, поэтому каждая запись выглядит так:

Т1.ID_RECORD, атрибут, новое значение, старое значение
При этом запись в журнал предшествует непосредственному выполнению операции над БД.
Когда встречается команда T1 COMMIT, и она выполняется, то все изменения оказываются уже внесенными в БД и не требуется никаких дальнейших действий по отношению к этой транзакции.

При откате транзакции выполняется системная процедура UNDO(), которая возвращает все старые значения в отмененной транзакции, последовательно проходя по протоколу, начиная с команды BEGIN TRANSACTION.



Слайд 54 Для восстановления при сбое используется следующий механизм:

Если

Для восстановления при сбое используется следующий механизм: Если транзакция содержит команду

транзакция содержит команду начала транзакции, но не содержит команду

фиксации с подтверждением ее выполнения, то выполняется последовательность действий как при откате транзакции, то есть восстанавливаются старые значения.



Слайд 55 На самом деле восстановление происходит по более сложным

На самом деле восстановление происходит по более сложным алгоритмам, т.к. изменения,

алгоритмам, т.к. изменения, как в журнал, так и в

БД заносятся не сразу, а буферизуются.


Если бы запись об изменении БД, которая должна поступать в журнал при выполнении любой операции модификации БД, на самом деле немедленно записывалась во внешнюю память, это привело бы к существенному замедлению работы системы.




Слайд 56
Основным принципом согласованной политики выталкивания буфера журнала и

Основным принципом согласованной политики выталкивания буфера журнала и буферов страниц базы

буферов страниц базы данных является то, что запись об

изменении объекта базы данных должна попадать во внешнюю память журнала раньше, чем изменённый объект оказывается во внешней памяти базы данных.
Соответствующий протокол журнализации (и управления буферизацией) называется Write Ahead Log (WAL) — "пиши сначала в журнал" и состоит в том, что если требуется записать во внешнюю память измененный объект базы данных, то перед этим нужно гарантировать запись во внешнюю память журнала транзакций записи о его изменении.


Слайд 57
Если во внешней памяти базы данных находится некоторый

Если во внешней памяти базы данных находится некоторый объект базы данных,

объект базы данных, по отношению к которому выполнена операция

модификации, то во внешней памяти журнала обязательно находится запись, соответствующая этой операции.

Обратное неверно, то есть если во внешней памяти журнале содержится запись о некоторой операции изменения объекта базы данных, то сам изменённый объект может отсутствовать во внешней памяти базы данных.

Слайд 58
UPDATE Table SET c1 = 10 WHERE c2

UPDATE Table SET c1 = 10 WHERE c2 LIKE '%Иванов%';Выполняются следующие

LIKE '%Иванов%';

Выполняются следующие операции.

Страницы данных из Table

считываются с диска в память, поэтому можно выполнять поиск соответствующих строк. Например оказывается, что на трех страницах данных имеется пять строк, соответствующих предикату предложения WHERE.
Автоматически запускается транзакция.
Эти три страницы блокируются для выполнения обновлений.
Изменения вносятся в пять записей данных на трех страницах данных, находящихся в памяти.
Изменения записываются в записи журнала транзакций на диске.
Автоматически фиксируется транзакция.

Слайд 59
Параллельная работа пользователей.
Проблемы параллельного выполнения: потерянное обновление,

Параллельная работа пользователей. Проблемы параллельного выполнения: потерянное обновление, доступ к промежуточным результатам транзакции, строки-фантомы.

доступ к промежуточным результатам транзакции, строки-фантомы.


Слайд 60
Когда множество пользователей одновременно пытаются модифицировать данные в

Когда множество пользователей одновременно пытаются модифицировать данные в БД, необходимо создать

БД, необходимо создать систему управления, которая защитила бы модификации,

выполненные одним пользователем, от негативного воздействия модификаций, сделанных другими. Этот процесс называется управлением параллельным выполнением.



Слайд 63 Управление блокировками

С помощью блокировок обеспечиваетcя целостность и согласованность

Управление блокировкамиС помощью блокировок обеспечиваетcя целостность и согласованность БД при параллельной

БД при параллельной работе.

Блокировки запрещают пользователям читать данные,

изменяемые другими пользователями, и предотвращают одновременную модификацию одних и тех же данных несколькими пользователями.

Без использования блокировок логическая целостность данных БД может нарушиться, в результате при запросе выводятся искажённые данные.



Слайд 64 Проблемы параллельного выполнения

Если несколько пользователей одновременно обращаются к

Проблемы параллельного выполненияЕсли несколько пользователей одновременно обращаются к БД при отсутствии

БД при отсутствии блокировок, возможны ошибки при одновременном использовании

в их транзакциях одних и тех же данных.



Слайд 65
•потерянные обновления;

•чтение незафиксированных данных ;

•несогласованный анализ (неповторяемое чтение);

•чтение

•потерянные обновления;•чтение незафиксированных данных ;•несогласованный анализ (неповторяемое чтение);•чтение фантомов.

фантомов.


Слайд 66 Потерянные обновления

Потерянные обновления появляются при выборе одной строки

Потерянные обновленияПотерянные обновления появляются при выборе одной строки двумя или более

двумя или более транзакциями, которые обновляют эту строку на

основе ее первоначального значения.

Ни у одной из транзакций нет сведений о действиях, выполненных другими транзакциями. Поэтому последнее обновление записывается поверх обновлений, сделанных другими транзакциями, что приводит к потере данных.



Слайд 67
Например, два редактора сделали копии одного и того

Например, два редактора сделали копии одного и того же документа. Затем

же документа. Затем внесли независимые изменения в свои копии

и сохранили их поверх исходного документа. При этом редактор, сохранивший измененную копию последним, записал свои изменения без учета изменений первого редактора, в результате какие-то данные оказались потеряны.
Подобной проблемы удастся избежать, если запретить второму редактору изменять документ, пока с ним не закончит работу первый редактор.

Слайд 69 Чтение незафиксированных данных (“грязное” чтение)
Чтение незафиксированных данных возникает,

Чтение незафиксированных данных (“грязное” чтение)Чтение незафиксированных данных возникает, когда вторая транзакция

когда вторая транзакция читает строку, которую в это время

обновляет первая транзакция. Таким образом, вторая транзакция читает ещё не зафиксированные данные, которые могут быть изменены первой транзакцией.

Например, редактор вносит изменения в электронный документ. В это время второй редактор делает копию документа со всеми изменениями, уже внесёнными первым редактором, и распространяет его в целевой аудитории.
После этого первый решает, что внесённые изменения не нужны, отменяет их и сохраняет документ. При этом распространённый документ содержит несуществующие, стало быть, недействительные правки.
Подобной проблемы можно избежать, если исключить возможность чтения изменяемого документа, пока первый редактор не признает внесенные изменения окончательными.



Слайд 70 В транзакции 1 изменяется значение поля f2, а

В транзакции 1 изменяется значение поля f2, а затем в транзакции

затем в транзакции 2 выбирается
значение этого поля.
После

этого происходит откат транзакции 1. В результате значение, полученное
второй транзакцией, будет отличаться от значения, хранимого в базе данных



Слайд 71 Несогласованный анализ (неповторяемое чтение)
Несогласованным анализом называется ситуация, когда

Несогласованный анализ (неповторяемое чтение)Несогласованным анализом называется ситуация, когда вторая транзакция несколько

вторая транзакция несколько раз обращается к той же строке,

что и первая, однако от раза к разу данные меняются. Несогласованный анализ напоминает чтение незафиксированных данных тем, что первая транзакция изменяет данные, которые читает вторая транзакция. Однако при несогласованном анализе первая транзакция подтверждает изменение этих данных. Кроме того, при несогласованном анализе происходит многократное {двукратное или больше) чтение второй транзакцией одной и той же строки с разными данными.

Например, редактор два раза читает один и тот же документ, а в промежутке между обращениями автор документа переделывает его. Значит, во второй раз редактор читает уже измененный документ.

Этого можно избежать, если редактору разрешить чтение документа лишь в окончательной форме.



Слайд 72 :
В транзакции 2 выбирается значение поля f2, затем

:В транзакции 2 выбирается значение поля f2, затем в транзакции 1

в транзакции 1 изменяется значение поля f2. При повторной

попытке выбора значения из поля f2 в транзакции 2 будет получен другой результат.



Слайд 73 Чтение фантомов
Так называется ситуация, когда строки из диапазона

Чтение фантомовТак называется ситуация, когда строки из диапазона строк, читаемого во

строк, читаемого во время транзакции, добавляются или удаляются. Первая

операция чтения, исполняемая во время транзакции, показывает наличие в прочитанном диапазоне некоторой строки. Если другая транзакция удалит ее, то эта строка не будет обнаружена, когда диапазон будет прочитан в следующий раз. Аналогично, если другая транзакция добавляет в читаемый диапазон строку после первого чтения, эта строка обнаружится только при повторном чтении.



Слайд 74 В транзакции 2 выполняется SQL-оператор, использующий
все значения

В транзакции 2 выполняется SQL-оператор, использующий все значения поля f2. Затем

поля f2. Затем в транзакции 1 выполняется вставка
новой

строки, приводящая к тому, что повторное выполнение
SQL-оператора в транзакции 2 выдаст другой результат. Такая ситуация
называется фантомным чтением. От неповторяющегося чтения
оно отличается тем, что результат повторного обращения
к данным изменился не из-за этих данных,
а из-за появления новых (фантомных) данных.



Слайд 76
Типы конфликтов между двумя параллельными транзакциями:

· W-W – транзакция

Типы конфликтов между двумя параллельными транзакциями:· W-W – транзакция 2 пытается изменить

2 пытается изменить объект, измененный не закончившейся транзакцией 1;

· R-W

– транзакция 2 пытается изменить объект, прочитанный не закончившейся транзакцией 1;

· W-R транзакция 2 пытается читать объект, измененный не закончившейся транзакцией 1.

Слайд 78 37. Определение блокировки. Управление блокировками в SQL Server.

37. Определение блокировки. Управление блокировками в SQL Server. Оптимистические и пессимистические стратегии блокировки. Блокируемые ресурсы.

Оптимистические и пессимистические стратегии блокировки. Блокируемые ресурсы.



Слайд 79
Блокировкой называется временное ограничение на выполнение некоторых операций

Блокировкой называется временное ограничение на выполнение некоторых операций обработки данных.Управлением блокировками

обработки данных.

Управлением блокировками на сервере занимается менеджер блокировок, контролирующий

их применение и разрешение конфликтов.



Слайд 80
Транзакции и блокировки тесно связаны друг с другом.

Транзакции и блокировки тесно связаны друг с другом. Транзакции накладывают блокировки



Транзакции накладывают блокировки на данные, чтобы обеспечить выполнение требований

ACID.

Без использования блокировок несколько транзакций могли бы изменять одни и те же данные.

Слайд 81
SQL Server поддерживает как оптимистическое, так и пессимистическое

SQL Server поддерживает как оптимистическое, так и пессимистическое управление параллельным выполнением.

управление параллельным выполнением.

По умолчанию в SQL Server применяется

пессимистическое управление параллельным выполнением.

Слайд 82 Оптимистическое параллельное выполнение

При оптимистическом управлении параллельным выполнением предполагается,

Оптимистическое параллельное выполнениеПри оптимистическом управлении параллельным выполнением предполагается, что конфликты из-за

что конфликты из-за ресурсов между несколькими пользователями маловероятны.

При оптимистическом

управлении параллелизмом данные на период чтения не блокируются.

Когда пользователь обновляет данные, система проверяет, вносил ли другой пользователь в них изменение после считывания. Если другой пользователь изменял данные, возникает ошибка. Как правило, при получении сообщения об ошибке пользователь откатывает транзакцию и начинает ее заново.
В основном применяется в средах с небольшим количеством конфликтов данных, где затраты на периодический откат транзакции меньше затрат на блокировку данных при считывании.



Слайд 83 Пессимистическое параллельное выполнение

Пессимистическое управление параллельным выполнением блокирует ресурсы,

Пессимистическое параллельное выполнениеПессимистическое управление параллельным выполнением блокирует ресурсы, затребованные транзакцией, чтобы

затребованные транзакцией, чтобы обеспечить ее устойчивость. Таким образом, гарантируется

успешное завершение транзакции, если не возникнет взаимоблокировки.

В основном применяется в средах с большим количеством конфликтов данных, где затраты на защиту данных с помощью блокировок меньше затрат на откат транзакций в случае конфликтов параллелизма.



Слайд 84
38. Уровни изоляции транзакций. Сериализуемые транзакции.
Уровни изоляции

38. Уровни изоляции транзакций. Сериализуемые транзакции. Уровни изоляции «повторяемое чтение», «завершенное

«повторяемое чтение», «завершенное чтение», «незавершенное чтение». Особенности обработки блокировок

и изоляции транзакций в MS SQL Server.

Слайд 85 Уровни изоляции

Проблемы, связанные с параллельным выполнением, разрешают, используя

Уровни изоляцииПроблемы, связанные с параллельным выполнением, разрешают, используя уровни изоляции (ISOLATION

уровни изоляции (ISOLATION LEVEL).

Это позволяет полностью изолировать выполняемые

транзакции друг от друга.



Слайд 86 Уровни изоляции обеспечивают правила параллелизма и последовательности работы

Уровни изоляции обеспечивают правила параллелизма и последовательности работы с данными. Когда

с данными.

Когда устанавливается уровень изоляции, множество пользователей, работающих

с одними и теми же наборами данных, устанавливают блокировки или следуют основанным на установленном уровне изоляции правилам.



Слайд 87 Уровни изоляции в стандарте SOL-99

Уровень изоляции определяет степень

Уровни изоляции в стандарте SOL-99Уровень изоляции определяет степень изоляции одной транзакции

изоляции одной транзакции от остальных.

Более низкий уровень изоляции

увеличивает возможность параллельного выполнения, но за это приходится расплачиваться согласованностью данных.

Напротив, более высокий уровень изоляции гарантирует согласованность данных, но при этом страдает параллельное выполнение.

Режим управления блокировками определяется уровнем изоляции, необходимым приложению.



Слайд 88 Стандарт SQL-99 определяет следующие уровни изоляции

•неподтверждаемое чтение READ

Стандарт SQL-99 определяет следующие уровни изоляции•неподтверждаемое чтение READ UNCOMMITTED (чтение незафиксированных

UNCOMMITTED (чтение незафиксированных данных)—самый низкий уровень;

READ UNCOMMITTED допускает грязное

чтение, неповторяемое чтение и фантомные записи.

Уровень изоляции READ UNCOMMITED обычно является весьма нежелательным и должен быть использован, только когда не требуется точности чтения данных или когда данные изменяются редко.



Слайд 89
•подтверждаемое чтение Read committed - чтение, при котором

•подтверждаемое чтение Read committed - чтение, при котором отсутствует черновое,

отсутствует черновое, "грязное" чтение (т.е. чтение пользователем данных, которые

не были зафиксированы в БД командой COMMIT).
Но могут изменяться уже прочитанные данные, результатом чего будет неповторяемое чтение или фантомные данные.

В Oracle блокировки на чтение нет, вместо этого «читающая» транзакция получает ту версию данных, которая была актуальна в базе до начала «пишущей».

Слайд 90 •повторяемое чтение (Repeatable read) - Уровень, при котором

•повторяемое чтение (Repeatable read) - Уровень, при котором чтение одной и

чтение одной и той же строки или строк в

транзакции дает одинаковый результат.

Указывает на то, что транзакциями не могут считывать данные, которые были изменены, но еще не зафиксированы другими транзакциями, а также на то, что другие транзакции не могут изменять данные, читаемые текущей транзакцией, до ее завершения.

Но другие транзакции могут вставлять новые строки, соответствующие условиям поиска, содержащихся в текущей транзакции. При повторном запуске инструкции текущей транзакцией будут извлечены новые строки, что приведет к фантомному чтению.
.



Слайд 91 •упорядочение (Serializable) —наивысший уровень, на котором транзакции полностью

•упорядочение (Serializable) —наивысший уровень, на котором транзакции полностью изолированы друг от

изолированы друг от друга.
На этом уровне результаты параллельного выполнения

транзакций для базы данных в большинстве случаев можно считать совпадающими с последовательным выполнением тех же транзакций.



Слайд 92 транзакции не могут считывать данные, которые были

транзакции не могут считывать данные, которые были изменены другими транзакциями,

изменены другими транзакциями, но еще не были зафиксированы.

Другие транзакции не могут изменять данные, считываемые текущей транзакцией, до ее завершения.

Другие транзакции не могут вставлять новые строки со значениями ключа, которые входят в диапазон ключей, считываемых инструкциями текущей транзакции, до ее завершения.



Слайд 93
Блокировки диапазона сохраняются до завершения транзакции.

Это самый

Блокировки диапазона сохраняются до завершения транзакции. Это самый строгий уровень изоляции,

строгий уровень изоляции, поскольку он блокирует целые диапазоны ключей

и сохраняет блокировку до завершения транзакции.

Из-за низкого параллелизма этот параметр рекомендуется использовать только при необходимости.

Слайд 94 По умолчанию, устанавливается изоляция Read Committed.

Основной принцип

По умолчанию, устанавливается изоляция Read Committed. Основной принцип состоит в том,

состоит в том, что пишущая транзакция блокирует данные и

читающие транзакции не могут их читать.

Когда установлен Read Committed, прочитать можно только сохранённые данные.



Слайд 95
Тривиальным решением является действительно последовательное выполнение транзакций.

Но

Тривиальным решением является действительно последовательное выполнение транзакций. Но существуют ситуации, в

существуют ситуации, в которых можно выполнять операторы разных транзакций

в любом порядке с сохранением свойства сериальности.

Примерами могут служить только читающие транзакции, а также транзакции, не конфликтующие по объектам базы данных.

Слайд 96
Блокировки, называемые также синхронизационными захватами объектов, могут быть

Блокировки, называемые также синхронизационными захватами объектов, могут быть применены к разному

применены к разному типу объектов.

Наибольшим объектом блокировки может

быть вся БД, однако этот вид блокировки сделает БД недоступной для всех приложений, которые работают с данной БД.

Следующий тип объекта блокировки — это таблицы. Транзакция, которая работает с таблицей, блокирует ее на все время выполнения транзакции. Этот вид блокировки предпочтительнее предыдущего, потому что позволяет параллельно выполнять транзакции, которые работают с другими таблицами.


Слайд 97
В ряде СУБД реализована блокировка на уровне страниц.

В ряде СУБД реализована блокировка на уровне страниц. В этом случае

В этом случае СУБД блокирует только отдельные страницы на

диске, когда транзакция обращается к ним. Этот вид блокировки ещё более мягок и позволяет разным транзакциям работать даже с одной и той же таблицей, если они обращаются к разным страницам данных.

В некоторых СУБД возможна блокировка на уровне строк, однако такой механизм блокировки требует дополнительных затрат на поддержку этого вида блокировки.

В настоящее время проблема блокировок является предметом большого числа исследований.

Слайд 99 Настройка блокировок

SQL Server реализует блокирование автоматически, но в

Настройка блокировокSQL Server реализует блокирование автоматически, но в приложениях эту функцию

приложениях эту функцию можно настроить следующими способами:

•задавая обработку взаимоблокировок

и установку приоритетов при взаимоблокировках;

•задавая обработку тайм-аутов и определяя продолжительность тайм-аута блокировки;

•устанавливая уровень изоляции транзакции;

•назначая блокировки на уровне таблицы с операторами SELECT, INSERT, UPDATE и DELETE.



Слайд 100 Обработка взаимоблокировок

Взаимоблокировка возникает, когда два или более потоков,

Обработка взаимоблокировокВзаимоблокировка возникает, когда два или более потоков, конкурирующих за ресурс, становятся взаимозависимыми.

конкурирующих за ресурс, становятся взаимозависимыми.



Слайд 101 Взаимоблокировка возникает, когда у каждой транзакции заблокирован ресурс,

Взаимоблокировка возникает, когда у каждой транзакции заблокирован ресурс, который пытаются заблокировать

который пытаются заблокировать другие транзакции.




Транзакция T1 блокирует ресурс

R1 и запросила блокировку ресурса R2.
Транзакция T2 блокирует ресурс R2 и запросила блокировку ресурса R1 .



Слайд 102 Так как ни одна из задач не может

Так как ни одна из задач не может продолжиться до тех

продолжиться до тех пор, пока не будет доступен ресурс,

а ни один из ресурсов не может быть освобожден до тех пор, пока задание не продолжится, наступает состояние взаимоблокировки.



Слайд 103

Обе транзакции находятся в состоянии взаимоблокировки и будут

Обе транзакции находятся в состоянии взаимоблокировки и будут всегда находиться в

всегда находиться в состоянии ожидания, если взаимоблокировка не будет

разрушена внешним процессом.

Монитор взаимоблокировок периодически проверяет задачи на состояние взаимоблокировки. Если монитор обнаруживает цикличную зависимость, то выбирается одна задача, для которой транзакция будет завершена с ошибкой.

Это позволяет другой задаче завершить свою транзакцию. Позднее приложение может повторно выполнить транзакцию, которая завершилась с ошибкой, обычно после того как другая транзакция (бывшая в состоянии взаимоблокировки) завершится.



Слайд 104 Минимизация числа взаимоблокировок

Хотя полностью избежать взаимоблокировок не удаётся,

Минимизация числа взаимоблокировокХотя полностью избежать взаимоблокировок не удаётся, их число можно

их число можно существенно уменьшить, чтобы увеличить пропускную способность

при обработке транзакций и снизить системные издержки, поскольку меньше транзакций будут подвергаться откату с отменой всей выполненной ими работы. Кроме того, уменьшится число транзакций, повторно переданных приложениями на сервер из-за отката в результате взаимоблокировок.



Слайд 105 Чтобы минимизировать число взаимоблокировок, необходимо придерживаться следующих правил:


•следить,

Чтобы минимизировать число взаимоблокировок, необходимо придерживаться следующих правил:•следить, чтобы транзакции были

чтобы транзакции были короткими и не выходили за пределы

одного пакета;

•использовать низкие уровни изоляции;



Слайд 106 Оператор SET LOCK_TIMEOUT позволяет задать максимальный период ожидания

Оператор SET LOCK_TIMEOUT позволяет задать максимальный период ожидания оператором освобождения ресурса.

оператором освобождения ресурса.

Если ожидание оператора продлилось дольше установленного

L0CK_TIMEОUT, оператор автоматически отменяется и приложению возвращается сообщение об ошибке 1222 Lock request time-out period exceeded (Превышение тайм-аута при ожидании блокировки).



Слайд 107 В приложении должен быть обработчик ошибок, перехватывающий сообщение

В приложении должен быть обработчик ошибок, перехватывающий сообщение об ошибке 1222.

об ошибке 1222.

Реализация обработчика ошибок, перехватывающего сообщение об

ошибке 1222, позволяет приложению обработать тайм-аут и предпринять меры для решения проблемы (например, выполнить откат всей транзакции).



Слайд 108
Основными режимами блокировок являются следующие:
совместный режим –

Основными режимами блокировок являются следующие: совместный режим – S (Shared), означающий

S (Shared), означающий совместную (по чтению) блокировку объекта и

требуемый для выполнения операции чтения объекта;

монопольный режим – X (eXclusive), означающий монопольную (по записи) блокировку объекта и требуемый для выполнения операций вставки, удаления и модификации объекта.

Слайд 109 Настройка уровней изоляции транзакции

По умолчанию SQL Server работает

Настройка уровней изоляции транзакцииПо умолчанию SQL Server работает на уровне изоляции

на уровне изоляции READ COMMITTED (подтвержденное чтение).

Однако для

работы приложения иногда требуется другой уровень изоляции. Чтобы использовать в приложениях более или менее строгие уровни изоляции, следует настроить блокировку для текущего сеанса, установив уровень изоляции сеанса с помощью оператора
SET TRANSACTION ISOLATION LEVEL
Например:
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE



Слайд 110
В некоторых СУБД возможна блокировка на уровне строк.

В некоторых СУБД возможна блокировка на уровне строк. MS SQL Server

MS SQL Server стремится установить блокировку на уровне записей,

чтобы обеспечить максимальную параллельность в работе.

С увеличением количества блокировок строк сервер может перейти к блокировке страниц, если количество записей превышает пороговое значения.

Слайд 111 Реализация указаний блокирования на уровне таблицы

Для операторов SELECT,

Реализация указаний блокирования на уровне таблицыДля операторов SELECT, INSERT, UPDATE и

INSERT, UPDATE и DELETE разрешается задавать ряд указаний блокирования

таблицы, определяющих тип используемой блокировки.

Указания блокирования на уровне таблицы служат для тонкой настройки типов блокировок, необходимых для объекта.

Указания блокирования подменяют текущий уровень изоляции транзакций сеанса.



Слайд 112
NOLOCK - можно читать неподтверждённые транзакции.

PAGLOCK -

NOLOCK - можно читать неподтверждённые транзакции. PAGLOCK - блокировка страницы.ROWLOCK -

блокировка страницы.

ROWLOCK - блокировка на уровне строк вместо более

грубых блокировок уровня страницы и таблицы.

TABLOCK - блокировка таблиц вместо более тонких блокировок уровня строк и страниц.



Слайд 113 В следующем примере установлен уровень изоляции транзакций SERIALIZABLE,

В следующем примере установлен уровень изоляции транзакций SERIALIZABLE, а также используется

а также используется указание блокировки на уровне таблицы с

оператором SELECT:

USE PROPERTY
GO
SET TRANSACTION ISOLATION LEVEL READ COMMITED
GO
BEGIN TRANSACTION
SELECT PROPERTY_NO FROM PROPERTY (tabLOCK)
GO



Слайд 114 При одновременном обращении нескольких пользователей к БД, когда

При одновременном обращении нескольких пользователей к БД, когда блокирование не применяется,

блокирование не применяется, весьма вероятно возникновение ошибки, если их

транзакции одновременно используют одни и те же данные.

Блокировки запрещают пользователям читать данные, изменяемые другими пользователями, а также не дают изменять одни и те же данные нескольким пользователям одновременно.


Проблемы параллельного выполнения возникают из-за потерянных обновлений, несогласованного анализа (неповторяемые данные) и чтения фантомов.



Слайд 115 Возможно оптимистическое и пессимистическое управление параллельным выполнением. При

Возможно оптимистическое и пессимистическое управление параллельным выполнением. При оптимистическом управлении параллельным

оптимистическом управлении параллельным выполнением предполагается, что конфликты нескольких пользователей

из-за ресурсов маловероятны. Этот режим позволяет исполнять транзакции без блокирования ресурсов.

Пессимистическое управление параллельным выполнением блокирует ресурсы на время исполнения транзакции. Таким образом, обеспечивается успешное завершение транзакции, если не возникает взаимоблокировка.



Слайд 116 Уровень изоляции —это степень, в которой одна транзакция

Уровень изоляции —это степень, в которой одна транзакция должна быть изолирована

должна быть изолирована от других.

SQL Server поддерживает следующие

уровни изоляции: неподтверждаемое чтение, подтверждаемое чтение, повторяемое чтение и упорядочение.
Хотя SQL Server реализует блокирование автоматически, его можно настроить, используя обработку взаимоблокировок, установку приоритета при взаимоблокировке, обработку тайм-аутов и определение длины тайм-аута блокировки, а также устанавливая уровни изоляции с помощью указаний блокирования на уровне таблицы и настройки блокирования.



  • Имя файла: tranzaktsii-i-blokirovki.pptx
  • Количество просмотров: 115
  • Количество скачиваний: 0