Учебно-практическое пособие москва 2017 ббк



Pdf көрінісі
бет206/243
Дата21.07.2022
өлшемі3,05 Mb.
#147663
түріУчебно-практическое пособие
1   ...   202   203   204   205   206   207   208   209   ...   243
Байланысты:
Язык SQL. Базовый курс

UPDATE bookings
SET total_amount = (
SELECT sum( amount )
FROM ticket_flights
WHERE ticket_no IN (
SELECT ticket_no
FROM tickets
WHERE book_ref = 'ABC123'
)
)
WHERE book_ref = 'ABC123';
UPDATE 1
Проверим, что получилось.
SELECT * FROM bookings WHERE book_ref = 'ABC123';
book_ref |
book_date
| total_amount
----------+------------------------+--------------
ABC123
| 2016-10-13 22:00:00+08 |
42000.00
(1 строка)
COMMIT;
COMMIT;
В начале главы говорилось о свойствах транзакций. Их удобно прокомментировать
на примере этой транзакции, в которой участвуют три таблицы.
Атомарность
го-
ворит о том, что либо транзакция выполняется и фиксируется полностью, либо не
фиксируется ни одна из ее операций. Поэтому в случае отказа сервера баз данных
в процессе выполнения транзакции и последующего восстановления состояния базы
данных те операции, которые уже были выполнены, будут отменены. Таким образом,
база данных будет приведена к тому
согласованному
состоянию, в котором она на-
ходилась до начала транзакции. При выборе соответствующего уровня
изоляции
эта
транзакция сможет выполняться, не подвергаясь помехам со стороны других парал-
лельных транзакций. После успешной фиксации всех выполненных изменений в базе
данных пользователь может быть уверен, что они станут
долговечными
и сохранятся
даже в случае сбоя в работе сервера.
216


9.6 Блокировки
Кроме поддержки уровней изоляции транзакций, PostgreSQL позволяет также созда-
вать явные блокировки данных как на уровне отдельных строк, так и на уровне це-
лых таблиц. Блокировки могут быть востребованы при проектировании транзакций с
уровнем изоляции, как правило, READ COMMITTED, когда требуется более детальное
управление параллельным выполнением транзакций. PostgreSQL предлагает много
различных видов блокировок, но мы ограничимся рассмотрением только двух из
них.
Команда SELECT имеет предложение FOR UPDATE, которое позволяет заблокировать
отдельные строки таблицы с целью их последующего обновления. Если одна тран-
закция заблокировала строки с помощью этой команды, тогда параллельные тран-
закции не смогут заблокировать эти же строки до тех пор, пока первая транзакция
не завершится, и тем самым блокировка не будет снята.
Проведем эксперимент, как и прежде, с использованием двух терминалов. Мы не бу-
дем приводить все вспомогательные команды создания и завершения транзакций, а
ограничимся только командами, выполняющими полезную работу.
Итак, на первом терминале организуйте транзакцию с уровнем изоляции READ
COMMITTED и выполните следующую команду:


Достарыңызбен бөлісу:
1   ...   202   203   204   205   206   207   208   209   ...   243




©engime.org 2024
әкімшілігінің қараңыз

    Басты бет