자동 증가 필드의 간격 수정: 자세한 설명
자동 증가 필드는 데이터베이스 레코드에 대한 고유 식별자를 생성하는 데 사용됩니다. 테이블. 그러나 시간이 지남에 따라 삽입 및 삭제 작업으로 인해 이러한 식별자 순서에 간격이 나타날 수 있습니다.
간격의 의미 없는 특성
주의하는 것이 중요합니다. 자동 증가 필드의 간격은 일반적으로 의미가 없습니다. 논리적인 목적을 제공하지 않으며 데이터 구성이나 참조에 의존해서는 안 됩니다. 자동 증가 필드의 주요 목적은 특정 순서나 순서를 유지하는 것이 아니라 각 레코드에 고유한 참조를 제공하는 것입니다.
간격 채우기
이러한 공백을 메우는 것은 직관적인 것처럼 보일 수 있지만 일반적으로 여러 가지 이유로 권장되지 않습니다.
그럼에도 불구하고 필요한 경우...
꼭 채워야 하는 경우 간격이 있는 경우 특정 상황에서 수행될 수 있습니다. 다음 단계에서는 자세한 설명을 제공합니다.
참조 업데이트 예
상위 테이블과 하위 테이블이 있다고 가정합니다. 다음 스키마를 사용합니다.
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) );
참조를 업데이트하려면 다음 단계를 따르세요.
이전 상위 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;
외래 키 확인 비활성화:
SET foreign_key_checks = 0;
새 ID로 상위 및 하위 테이블 업데이트:
UPDATE Parent, Child, NewIds SET Parent.ParentId = NewIds.Id, Child.ParentId = NewIds.Id WHERE Parent.ParentId = NewIds.ParentId AND Child.ParentId = NewIds.ParentId;
외래 키 검사 다시 활성화:
SET foreign_key_checks = 1;
임시 테이블 삭제:
DROP TABLE NewIds;
다음을 따르세요. 단계에서는 임시 테이블에 생성된 새로운 순서 ID를 반영하도록 상위 및 하위 참조를 업데이트할 수 있습니다.
위 내용은 데이터베이스의 자동 증가 필드의 공백을 채워야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!