Я думаю, что нет.Мои уровни изоляции / шпаргалки MySQL недоступны, но я думаю, что они будут атомарными на уровне строк (UPDATE будет использовать блокировку диапазона IIRC), но не на уровне таблиц.
Теперь более интересный вопрос, чем то, является ли UPDATE атомарным, когда неатомарность UPDATE равна наблюдаемой .Ответ заключается в том, что отдельные операторы на уровне изоляции READ UNCOMMITTED могут наблюдать неатомарность UPDATE, а ряд связанных операторов в одной транзакции на уровне изоляции READ COMMITTED может наблюдать различные обновления.REPEATABLE READ и SERIALIZABLE видят ОБНОВЛЕНИЯ, как если бы они были атомарными и согласованными.
Представьте себе два сеанса.Сеанс A имеет уровень изоляции SERIALIZABLE и выполняет: UPDATE tokens SET tokens = tokens + 1
в таблице с 1000 строками.
- Предположим, что сеанс B имеет уровень изоляции READ UNCOMMITTED и выполняет
SELECT sum(tokens) FROM tokens
→ Этот выбор может видеть частичное обновление (то есть: некоторые строки обновлены, а другие строки не обновлены). - Предположим, что сеанс B имеет уровень изоляции READ COMMITTED и выполняет
SELECT sum(tokens) FROM tokens
→ Этот выбор не может видеть частичное обновление, поэтому он видит UPDATE, как если бы он был атомарным. - Предположим, что сеанс B имеет уровень изоляции READ COMMITTED и выполняет
SELECT sum(tokens) FROM tokens WHERE id BETWEEN 1 AND 100; SELECT sum(tokens) FROM tokens WHERE id BETWEEN 501 AND 600
, а затем некоторая логика программы добавляет эти два значения → Эти SELECT могут видеть разные снимки MVCC → разные обновления, - Предположим, сеанс Bимеет уровень изоляции REPEATABLE READ и выполняет
SELECT sum(tokens) FROM tokens WHERE id BETWEEN 1 AND 100; SELECT sum(tokens) FROM tokens WHERE id BETWEEN 501 AND 600
, а затем некоторая программная логика добавляет эти два значения → Эти SELECT не могут видеть разные снимки MVCC → они видят одно и то же обновление,