> 데이터 베이스 > MySQL 튜토리얼 > 데이터베이스의 자동 증가 필드의 공백을 채워야 합니까?

데이터베이스의 자동 증가 필드의 공백을 채워야 합니까?

DDD
풀어 주다: 2024-11-18 22:59:02
원래의
443명이 탐색했습니다.

Should You Fill Gaps in Auto-Increment Fields in Your Database?

자동 증가 필드의 간격 수정: 자세한 설명

자동 증가 필드는 데이터베이스 레코드에 대한 고유 식별자를 생성하는 데 사용됩니다. 테이블. 그러나 시간이 지남에 따라 삽입 및 삭제 작업으로 인해 이러한 식별자 순서에 간격이 나타날 수 있습니다.

간격의 의미 없는 특성

주의하는 것이 중요합니다. 자동 증가 필드의 간격은 일반적으로 의미가 없습니다. 논리적인 목적을 제공하지 않으며 데이터 구성이나 참조에 의존해서는 안 됩니다. 자동 증가 필드의 주요 목적은 특정 순서나 순서를 유지하는 것이 아니라 각 레코드에 고유한 참조를 제공하는 것입니다.

간격 채우기

이러한 공백을 메우는 것은 직관적인 것처럼 보일 수 있지만 일반적으로 여러 가지 이유로 권장되지 않습니다.

  • 공백은 의미가 없으며 데이터의 무결성이나 유용성에 영향을 주지 않습니다.
  • 시도 공백을 채우면 데이터베이스에 오류나 불일치가 발생할 수 있습니다.

그럼에도 불구하고 필요한 경우...

꼭 채워야 하는 경우 간격이 있는 경우 특정 상황에서 수행될 수 있습니다. 다음 단계에서는 자세한 설명을 제공합니다.

  1. 임시 테이블 생성: 자동 증가 열을 사용하여 기존 ID를 새로운 순차 ID에 매핑하는 임시 테이블을 생성합니다.
  2. 이전 ID 삽입: 임시 테이블을 원래 테이블의 이전 ID로 오름차순으로 채웁니다.
  3. 외래 키 제약 조건 삭제: 임시 테이블을 비활성화합니다. 업데이트 중 데이터 손상을 방지하기 위해 이전 ID를 참조하는 외래 키 제약 조건
  4. 참조 업데이트: 원본 테이블 및 관련 테이블의 이전 ID에 대한 모든 참조를 임시 테이블.
  5. 제약 조건 다시 활성화: 모든 참조가 업데이트되면 외래 키 제약 조건을 다시 활성화하여 참조 무결성을 유지합니다.
  6. 임시 삭제 테이블: 임시 테이블을 삭제하여 리소스를 정리합니다.

참조 업데이트 예

상위 테이블과 하위 테이블이 있다고 가정합니다. 다음 스키마를 사용합니다.

CREATE TABLE Parent (
    ParentId INT UNSIGNED AUTO_INCREMENT,
    Value INT UNSIGNED,
    PRIMARY KEY (ParentId)
);

CREATE TABLE Child (
    ChildId INT UNSIGNED AUTO_INCREMENT,
    ParentId INT UNSIGNED,
    PRIMARY KEY (ChildId),
    FOREIGN KEY (ParentId) REFERENCES Parent (ParentId)
);
로그인 후 복사

참조를 업데이트하려면 다음 단계를 따르세요.

  1. 이전 상위 ID를 새 ID에 매핑하는 임시 테이블을 만듭니다.

    CREATE TEMPORARY TABLE NewIDs (
        Id INT UNSIGNED AUTO_INCREMENT,
        ParentId INT UNSIGNED
    );
    
    INSERT INTO NewIDs (ParentId)
    SELECT ParentId
    FROM Parent
    ORDER BY ParentId ASC;
    로그인 후 복사
  2. 외래 키 확인 비활성화:

    SET foreign_key_checks = 0;
    로그인 후 복사
  3. 새 ID로 상위 및 하위 테이블 업데이트:

    UPDATE Parent,
    Child,
    NewIds
    SET
        Parent.ParentId = NewIds.Id,
        Child.ParentId = NewIds.Id
    WHERE
        Parent.ParentId = NewIds.ParentId AND
        Child.ParentId = NewIds.ParentId;
    로그인 후 복사
  4. 외래 키 검사 다시 활성화:

    SET foreign_key_checks = 1;
    로그인 후 복사
  5. 임시 테이블 삭제:

    DROP TABLE NewIds;
    로그인 후 복사

다음을 따르세요. 단계에서는 임시 테이블에 생성된 새로운 순서 ID를 반영하도록 상위 및 하위 참조를 업데이트할 수 있습니다.

위 내용은 데이터베이스의 자동 증가 필드의 공백을 채워야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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