Теперь нам предстоит разобраться, каким образом можно сымитировать транзакцию с помощью механизма блокировок таблиц. Объясним это на одном из предыдущих примеров, который состоял в добавлении нового работника в базу данных компании с блокировками и таблицами MyISAM вместо первоначального кода, в котором использовались таблицы InnoDB.
Первый шаг заключается в создании списка таблиц, которые будут использоваться во время транзакции. В предыдущем примере было три шага: (1) создание записи о работнике в таблице employees, (2) обозначение принадлежности работника к определенному отделу в таблице departments и (3) определение заработной платы и надбавок работника в таблице payroll.
Так как каждая из трех таблиц модифицируется при добавлении нового работника, они должны быть заблокированы в режиме WRITE, чтобы другие сеансы никак не смогли повлиять на процесс.
Листинг 12.34.
mysql> LOCK TABLES employees WRITE, departments WRITE, payroll WRITE;
Query OK, 0 rows affected (0.00 sec)
Как уже говорилось, режим WRITE предполагает, что другие сеансы не смогут ни читать, ни писать в заблокированные таблицы до тех пор, пока блокировка не будет снята. Следовательно, транзакция должна быть предельно краткой, для того чтобы избежать торможения других запросов к этим таблицами.
Добавим в эти таблицы новые записи.
Листинг 12.35.
mysql> INSERT INTO employees (ename, enationality) VALUES ('Tim Jonez', 'US');
Query OK, 1 row affected (0.13 sec)
mysql> INSERT INTO departments (eid, dept) VALUES (LAST_INSERT_ID(),
'Accounts');
Query OK, 1 row affected (0.03 sec)
mysql> INSERT INTO payroll (eid, pbasic, pbonus) VALUES
(LAST_INSERT_IDO, 36000.00, 2500.00);
Query OK, 1 row affected (0.02 sec)
Правильность ввода данных проверяется с помощью быстрого оператора SELECT .
До тех пор пока все три таблицы будут заблокированы, другие сеансы, пытающиеся получить доступ, будут вынуждены ожидать. Здесь явно не хватает изящного подхода с использованием транзакций, при котором блокировки на уровне страниц и строк позволяют другим клиентам работать с данными даже во время выполнения транзакции. Однако можно сказать, что блокировка таблиц помогает изолировать операции обновления различных сеансов друг от друга (хотя и в несколько примитивной манере), а значит, помогают пользователям, привязанным к таблицам старого типа, которые не поддерживают механизма транзакций, реализовывать при создании своих приложений среду, поддерживающую обработку псевдотранзакций.
Резюме
В этой главе обсуждается одна из наиболее существенных доработок, сделанных в MySQL: возможность группировки нескольких SQL-операторов в один целостный блок транзакции, который выполняется автоматически. Наряду с двоичным регистрационным журналом, в котором фиксируются все изменения, происходящие в реляционной СУБД, возможность обработки транзакций позволяет выполнять SQL-запросы в более безопасном режиме, а в случае возникновения ошибки, вернуть СУБД в исходное более стабильное состояние. Таким образом, поддержка транзакций играет важную роль в том, чтобы повысить надежность SQL-приложений и снизить вероятность разрушения данных ошибочными SQL-запросами. Наконец, благодаря такому преимуществу MySQL смогла стать серьезной альтернативой другим коммерческим СУБД.
Вследствие большого потребления ресурсов, транзакции приводят к существенному снижению производительности реляционной СУБД. Эти ресурсы необходимы для разделения транзакций при одновременном доступе пользователей к одним и тем же данным. Поэтому, кроме обсуждения жизненного цикла транзакции, данная глава также включает описание различных переменных MySQL, управляющих поведением транзакций, наиболее важной из которых является переменная TRANSACTION ISOLATION LEVEL, которая определяет степень изолированности транзакций друг от друга.
Наконец, из-за того, что транзакции поддерживаются только новыми таблицами InnoDB и BDB, в данной главе вкратце объясняется то, как можно смоделировать среду, поддерживающую обработку транзакций при работе со старым форматом таблиц MyISAM, с использованием простого и поэтому эффективного механизма блокировки таблиц.
ТОП-10 популярных
Для работы с вещественными числами в MySQL предусмотрено три типа данных - это типы FLOAT, DOUBLE, DECIMAL. Числовой тип FLOAT...
БОЛЬШЕ БОЛЬШИХ LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Больше больших LCD-мониторов
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
Процесс вытеснения с рынка мониторов с электронно-лучевой трубкой (CRT) продолжается. О смещении акцентов в пользу LCD-мониторов теперь заявляют даже те...
НОУТБУК с блестящим экраном
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Eсли выпустившая ноутбук фирма предлагает его в качестве «замены настольному ПК», то это должно подразумевать под собой нечто большее, чем...
Иди и пиши. TravelMate C100
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Планшетный компьютер платформы Tablet PC обязан в первую очередь быть легким, способным достаточно долго работать без подзарядки батарей. Эти требования...
Магнито-оптический дисковод DynaMO
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Cейчас, когда традиционные флоппи-дисководы на долгие годы замерли в своем развитии, поиск альтернативных носителей продолжается, и ситуация, казалось бы, разрешилась...
Компьютер для гурманов.«Эксимер ДМ»
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Российская компания «Эксимер ДМ», известная как производитель настольных компьютеров, рабочих станций, серверов и ноутбуков, выступила техническим спонсором проведения торжеств, посвященных...
Для длинных строк, т.е. строк длиннее 255 символов, в MySQL предусмотрены типы BLOB (Binary Large Object, большой двоичный объект) и...
В дополнение к календарным типам, предназначенным для хранения даты и времени отдельно, MySQL также поддерживает гибридные типы данных DATETIME и...
Вообще, к изменению настроек сервера прибегают очень редко. В MySQL программа заранее настроена так, чтобы соответствовать самым распространенным и основным...
Все о MySQL. Реализация псевдотранзакций с помощью механизма блокировки таблиц
28-12-2009
<< Предыдущая статья | Следующая статья >> |
Все о MySQL. Блокировка write | Все о MySQL. Администрирование и настройка |