>  기사  >  데이터 베이스  >  Mysql InnoDB가 비즈니스와 관련이 없는 자동 증가 기본 키를 추가하는 이유는 무엇입니까?

Mysql InnoDB가 비즈니스와 관련이 없는 자동 증가 기본 키를 추가하는 이유는 무엇입니까?

高洛峰
高洛峰원래의
2016-12-02 13:26:131409검색

Mysql 테이블 디자인에서는 업무와 관련 없는 자동 증가 컬럼을 기본 키로 사용하는 경우가 많습니다.
Mysql은 기본적으로 B-Tree 인덱스를 사용하기 때문에 간단히 "정렬된 빠른 검색 구조"로 이해하면 됩니다.
다음은 2계층 B+ 트리인 B-Tree의 구조 다이어그램입니다. 각 페이지의 팬아웃은 4이고 상위 레코드는 최소값을 저장합니다. 각 페이지는 양방향 연결 목록을 통과합니다.

Mysql InnoDB가 비즈니스와 관련이 없는 자동 증가 기본 키를 추가하는 이유는 무엇입니까?레코드 7을 삽입하면 페이지 분할이 발생합니다.

Mysql InnoDB가 비즈니스와 관련이 없는 자동 증가 기본 키를 추가하는 이유는 무엇입니까?

위에서 볼 수 있듯이 분할하면 기록 이동이 발생합니다. 그러나 최적화된 분할 작업에는 기록 이동이 필요하지 않습니다.

Mysql InnoDB가 비즈니스와 관련이 없는 자동 증가 기본 키를 추가하는 이유는 무엇입니까?

InnoDB 구현에서는 각각에 대해 마지막으로 삽입된 위치가 유지됩니다. 색인 페이지와 마지막 삽입은 증가/감소 식별자입니다. 이 정보를 기반으로 InnoDB는 페이지에 새로 삽입된 레코드가 여전히 증가/감소 제약 조건을 충족하는지 확인할 수 있습니다. 제약 조건이 충족되면 최적화된 분할 전략이 채택됩니다.
따라서 시퀀스를 사용하는 것이 좋습니다. 기본 키로 ID를 순차적으로 증가시키지만 순차적 증가를 충족하는 한 데이터베이스의 자동 증가 필드일 필요는 없습니다. 많은 대규모 애플리케이션에는 순차적으로 증가하는 ID 생성기가 있습니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.