Учебное пособие Санкт-Петербург «бхв-петербург»



Pdf көрінісі
бет212/256
Дата18.11.2022
өлшемі1.88 Mb.
#465124
түріУчебное пособие
1   ...   208   209   210   211   212   213   214   215   ...   256
sql osnovi yazika

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;
В начале главы говорилось о свойствах транзакций. Их удобно прокомментировать
на примере этой транзакции, в которой участвуют три таблицы. Атомарность го-
ворит о том, что либо транзакция выполняется и фиксируется полностью, либо не
фиксируется ни одна из ее операций. Поэтому в случае отказа сервера баз данных
в процессе выполнения транзакции и последующего восстановления состояния базы
данных те операции, которые уже были выполнены, будут отменены. Таким образом,
база данных будет приведена к тому согласованному состоянию, в котором она на-
ходилась до начала транзакции. При выборе соответствующего уровня изоляции эта
транзакция сможет выполняться, не подвергаясь помехам со стороны других парал-
лельных транзакций. После успешной фиксации всех выполненных изменений в базе
данных пользователь может быть уверен, что они станут долговечными и сохранятся
даже в случае сбоя в работе сервера.
277


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


Достарыңызбен бөлісу:
1   ...   208   209   210   211   212   213   214   215   ...   256




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

    Басты бет