mysql의 기본 트랜잭션 격리 수준은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

MySQL에 모든 데이터베이스를 표시하려면 ShowDatabases 명령을 사용해야합니다. 1. MySQL 서버에 로그인 한 후 ShowDatabase를 실행할 수 있습니다. 현재 사용자가 액세스 할 권한이있는 모든 데이터베이스를 나열하도록 명령. 2. Information_Schema, MySQL, Performance_Schema 및 SYS와 같은 시스템 데이터베이스는 기본적으로 존재하지만 권한이 부족한 사용자는이를 볼 수 없을 수 있습니다. 3. SelectSchema_namefrominformation_schema.schemata를 통해 데이터베이스를 쿼리하고 필터링 할 수도 있습니다. 예를 들어, 사용자가 만든 데이터베이스 만 표시하려면 시스템 데이터베이스를 제외합니다. 사용하십시오

기존 테이블에 기본 키를 추가하려면 AddPrimarykey 절을 사용하여 Altertable 문을 사용하십시오. 1. 대상 열에 널 값이없고 복제가 없으며 NOTNULL로 정의되어 있는지 확인하십시오. 2. 단일 열차 기본 키 구문은 Altertable 테이블 이름 AddPrimaryKey (열 이름)입니다. 3. 멀티 컬럼 조합 기본 키 구문은 Altertable 테이블 이름 AddPrimaryKey (열 1, 열 2)입니다. 4. 열에서 NULL을 허용하는 경우 먼저 NOTNULL을 설정하도록 수정을 실행해야합니다. 5. 각 테이블에는 하나의 기본 키만이있을 수 있으며 추가하기 전에 기존 기본 키를 삭제해야합니다. 6. 직접 늘려야하는 경우 modify를 사용하여 auto_increment를 설정할 수 있습니다. 작동하기 전에 데이터를 확인하십시오

MySQL 서비스가 실행 중인지 확인하고 sudosystemctlstatusmysql을 사용하여 확인하고 시작하십시오. 2. 원격 연결을 허용하고 서비스를 다시 시작하기 위해 BAND-ADDRESS가 0.0.0.0으로 설정되어 있는지 확인하십시오. 3. 3306 포트가 열려 있는지 확인하고 포트를 허용하도록 방화벽 규칙을 확인하고 구성하십시오. 4. "AccessDenied"오류의 경우 사용자 이름, 비밀번호 및 호스트 이름을 확인한 다음 MySQL에 로그인하여 MySQL.user 테이블을 쿼리하여 권한을 확인해야합니다. 필요한 경우 사용자를 생성하거나 업데이트하여 'Your_user'@'%'사용과 같은 승인; 5. Caching_sha2_password로 인해 인증이 손실 된 경우

mysqldump를 사용하는 것이 MySQL 데이터베이스를 백업하는 가장 일반적이고 효과적인 방법입니다. 테이블 구조 및 데이터가 포함 된 SQL 스크립트를 생성 할 수 있습니다. 1. 기본 구문은 다음과 같습니다. mysqldump-u [user name] -p [database name]> backup_file.sql입니다. 실행 후 암호를 입력하여 백업 파일을 생성하십시오. 2.-databases 옵션으로 여러 데이터베이스를 백업 옵션 : mysqldump-uroot-p-- databasesdb1db2> multip_dbs_backup.sql. 3. all-databases : mysqldump-uroot-p를 사용하여 모든 데이터베이스를 백업합니다

b-treeindexesarebestformostphpapplications, asysupportequalityandrangequeries, 분류, andareidealforcolumnsusedinwhere, ororderbyclauses;

UnionleMovesDuplicates는 Duplicates; 1.unionperformsDeduplicationBysorting 및 ComcomparingRows, ReturnOnlyUniqueresults, whathitSlowerOnlargedAtasets;

Group_Concat () 함수에서 분리기 키워드를 사용하여 분리기를 사용자 정의 할 수 있습니다. 1. 분리기를 사용하여 구분 기호와 같은 사용자 정의 분리기를 지정하십시오. '분리기는 세미콜론 및 플러스 공간으로 변경할 수 있습니다. 2. 일반적인 예제에는 파이프 문자 '|', space '', 라인 브레이크 문자 '\ n'또는 사용자 정의 문자열 '->'가 포함됩니다. 3. 분리기는 문자열 리터럴 또는 표현식이어야하며 결과 길이는 Group_Concat_Max_Len 변수에 의해 제한되며 SetSessionGroup_CONCAT_MAX_LEN = 100000으로 조정할 수 있습니다. 4. 분리기는 선택 사항입니다

Locktables를 사용하여 수동으로 테이블을 잠글 수 있습니다. 읽기 잠금은 여러 세션을 읽을 수 있지만 쓸 수는 없습니다. Write Lock은 현재 세션에 대한 독점 읽기 및 쓰기 권한을 제공하며 다른 세션은 읽고 쓸 수 없습니다. 2. 잠금은 현재 연결을위한 것입니다. STARTTRANSACTION 및 기타 명령의 실행은 암시 적으로 잠금을 해제합니다. 잠금 후 잠긴 테이블에만 액세스 할 수 있습니다. 3. MyISAM 테이블 유지 보수 및 데이터 백업과 같은 특정 시나리오에서만 사용하십시오. InnoDB는 성능 문제를 피하기 위해 Select ... ForupDate와 같은 트랜잭션 및로드 레벨 잠금을 사용하는 데 우선 순위를 부여해야합니다. 4. 작업이 완료된 후 잠금 해제 가능성을 명시 적으로 릴리스해야합니다. 그렇지 않으면 자원 막힘이 발생할 수 있습니다.