Изоляция транзакций определяет, насколько одна транзакция может видеть промежуточные изменения других параллельно выполняющихся транзакций.
Стандарт SQL определяет четыре уровня изоляции:
- Read Uncommitted (Чтение незафиксированных данных): Самый низкий уровень. Транзакция может читать незафиксированные изменения других транзакций (до "грязного" чтения).
- Read Committed (Чтение зафиксированных данных): Транзакция может читать только данные, которые были зафиксированы другими транзакциями. Избегает "грязного" чтения.
- Repeatable Read (Повторяемость чтения): Транзакция гарантирует, что данные, прочитанные в течение транзакции, не изменятся другими транзакциями при повторном чтении. Избегает "грязного" чтения и "неповторяющегося" чтения. Возможны "фантомы".
- Serializable (Сериализуемый): Самый высокий уровень изоляции. Гарантирует, что параллельные транзакции выполняются так, будто они выполнялись последовательно. Избегает всех типов нежелательных явлений: "грязного" чтения, "неповторяющегося" чтения и "фантомов".
Нежелательные явления при параллельном выполнении транзакций:
- Dirty Read (Грязное чтение): Транзакция A читает данные, модифицированные Транзакцией B, которые еще не зафиксированы. Если