mysql의 기본 트랜잭션 격리 수준은 커밋되지 않은 읽기, 커밋된 읽기, 반복 가능한 읽기 및 직렬화 가능입니다. 1. 커밋되지 않은 읽기(Read Uncommitted)는 이 격리 수준에서 트랜잭션이 다른 트랜잭션의 커밋되지 않은 데이터를 읽을 수 있음을 의미합니다. 2. 커밋된 읽기(Read Committed)는 이 격리 수준에서 트랜잭션이 제출된 데이터만 읽을 수 있음을 의미합니다. .
MySQL에는 커밋되지 않은 읽기(커밋되지 않은 읽기), 커밋된 읽기(커밋된 읽기), 반복 가능이라는 네 가지 기본 트랜잭션 격리 수준이 있습니다. 읽기(반복 읽기) 및 직렬화 가능(직렬화). 각 격리 수준은 아래에서 소개되고 자세히 설명됩니다.
1. 커밋되지 않은 읽기: 이 격리 수준에서 트랜잭션은 다른 트랜잭션에서 커밋되지 않은 데이터를 읽을 수 있음을 의미합니다. 이 격리 수준은 가장 낮으며 더티 읽기(Dirty 읽기) 질문입니다. 더티 읽기는 트랜잭션이 커밋되지 않은 다른 트랜잭션에서 데이터를 읽은 후 트랜잭션이 롤백되면 읽은 데이터가 유효하지 않음을 의미합니다.
2. 읽어보세요. 커밋됨: 이 격리 수준에서는 트랜잭션이 제출된 데이터만 읽을 수 있음을 의미합니다. 이 격리 수준은 더티 읽기 문제를 해결할 수 있지만 반복 불가능한 읽기의 원인이 됩니다. 읽기) 질문입니다. 반복 불가능 읽기는 트랜잭션 내에서 동일한 데이터를 여러 번 읽을 때 읽기 결과가 일관되지 않음을 의미합니다.
3. 읽기: 이 격리 수준에서 트랜잭션이 동일한 데이터를 반복적으로 읽을 수 있으며 읽기 결과가 항상 일관됨을 의미합니다. 이 격리 수준은 반복 불가능한 읽기 문제를 해결할 수 있지만 팬텀 읽기(팬텀 읽기)가 발생합니다. 읽기) 질문입니다. 팬텀 읽기는 트랜잭션 내에서 동일한 쿼리가 여러 번 실행되고 조건에 맞는 새로운 데이터가 결과 세트에 추가되는 것을 의미합니다.
4. 직렬화 가능: 이 격리 수준에서는 트랜잭션이 엄격하게 순차적으로 실행되며 동시 실행이 허용되지 않음을 의미합니다. 이 격리 수준은 팬텀 읽기 문제를 해결할 수 있지만 시스템의 동시성 성능에 영향을 미칩니다.
위의 네 가지 격리 수준 외에도 MySQL은 기본적으로 기본 격리 수준(Default)이라는 특별한 격리 수준도 제공합니다. 기본 격리 수준은 서버의 전역 변수 sql_mode에 의해 결정됩니다. sql_mode가 STRICT_ALL_TABLES, STRICT_TRANS_TABLES 또는 STRICT_ALL_TABLES와 STRICT_TRANS_TABLES의 조합인 경우 기본 격리 수준은 REPEATABLE입니다. 읽다. sql_mode에 위의 값이 포함되어 있지 않으면 기본 격리 수준은 READ COMMITTED입니다.
실제 적용에서는 적절한 격리 수준을 선택하는 것이 매우 중요합니다. 애플리케이션의 데이터 일관성에 대한 요구 사항이 더 높은 경우 반복 가능과 같은 더 높은 격리 수준을 선택할 수 있습니다. 읽기 또는 직렬화 가능. 데이터 일관성 요구 사항이 낮고 동시성 성능 요구 사항이 높은 경우 커밋된 읽기와 같은 낮은 격리 수준을 선택할 수 있습니다.
또한 MySQL은 트랜잭션 격리 수준을 설정하는 방법도 제공합니다. 트랜잭션 격리 수준은 세션 수준 또는 전역 수준 변수 transaction_isolation을 설정하여 수정할 수 있습니다. 예를 들어 다음 문을 사용하여 격리 수준을 읽기로 수정할 수 있습니다. 커밋됨:
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
요약하면 MySQL의 기본 트랜잭션 격리 수준에는 커밋되지 않은 읽기, 커밋된 읽기, 반복 가능이 포함됩니다. 읽기, 직렬화 가능 및 기본 격리 수준. 데이터 일관성을 보장하고 동시성 성능을 향상시키려면 적절한 격리 수준을 선택하는 것이 중요합니다.
위 내용은 mysql의 기본 트랜잭션 격리 수준은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!