> 데이터 베이스 > MySQL 튜토리얼 > 테이블을 잠그지 않고 MySQL ALTER TABLE 작업을 수행할 수 있습니까?

테이블을 잠그지 않고 MySQL ALTER TABLE 작업을 수행할 수 있습니까?

Barbara Streisand
풀어 주다: 2024-12-24 17:14:15
원래의
789명이 탐색했습니다.

Can MySQL ALTER TABLE Operations Be Performed Without Locking the Table?

테이블을 잠그지 않고 테이블 작업 변경을 수행할 수 있습니까?

MySQL의 ALTER TABLE 문은 테이블에 읽기 잠금을 적용하여 테이블을 잠그지 않습니다. 모든 동시 쓰기. 이는 장기간 동안 INSERT 또는 UPDATE 문이 차단될 수 있으므로 대형 테이블의 경우 상당한 불편을 초래할 수 있습니다. 열을 추가하는 동안 업데이트를 허용하는 "핫 변경"에 대한 솔루션이 있는지 이해하는 것이 중요합니다.

수동 접근 방식

기본 지원이 없는 경우 최신 변경의 경우 유일한 대안은 많은 RDBMS 시스템이 사용하는 프로세스를 수동으로 복제하는 것입니다. 여기에는 다음이 포함됩니다.

  1. 새 테이블 생성
  2. 이전 테이블의 데이터를 청크로 복사하고, 소스 테이블에서 진행 중인 INSERT/UPDATE/DELETE 작업으로 인해 발생할 수 있는 충돌을 관리합니다.
  3. 이전 테이블의 이름을 바꾼 후 새 테이블의 이름을 바꿉니다(이상적으로는 트랜잭션).
  4. 실행 계획 유효성을 유지하기 위해 저장 프로시저 및 기타 종속 개체를 재컴파일합니다.

Hot Alters 부족에 대한 정당성

MySQL이 핫에 대한 기본 지원이 부족한 이유를 고려해 볼 가치가 있습니다. alters:

  • 필드를 추가하는 것은 모든 행의 필드를 변경하는 것과 같으며 이는 중요한 작업입니다.
  • 필드 잠금은 행 잠금보다 구현하기가 더 복잡합니다.
  • 물리적 디스크 구조를 업데이트하려면 모든 레코드를 재배치해야 합니다.
  • 이 프로세스는 전체 테이블과 유사합니다. 업데이트를 통해 일반 업데이트보다 근본적으로 더 큰 영향력을 발휘할 수 있습니다.

위 내용은 테이블을 잠그지 않고 MySQL ALTER TABLE 작업을 수행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿