>데이터 베이스 >MySQL 튜토리얼 >임시 테이블 없이 MySQL 기본 인덱스 번호를 다시 매기는 방법은 무엇입니까?

임시 테이블 없이 MySQL 기본 인덱스 번호를 다시 매기는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-25 02:53:291016검색

How to Renumber Your MySQL Primary Index Without Temporary Tables?

MySQL 기본 인덱스의 효율적인 번호 다시 매기기

MySQL에서는 번호가 매겨진 기본 인덱스를 유지하는 것이 데이터 일관성과 성능에 매우 중요합니다. 그러나 수동으로 변경하거나 데이터를 가져오면 색인 번호 매기기에 공백이 생겨 순서가 혼란스러울 수 있습니다. 이 문서에서는 임시 테이블을 생성하지 않고 기본 인덱스의 번호를 다시 매기는 대체 방법을 소개합니다.

이 방법을 실행하려면:

  1. 카운터 변수 설정: 변수 초기화 SET 문을 사용하여 @i를 0으로 변경합니다.
  2. 열 값 업데이트: UPDATE 문을 사용하여 @i의 증가된 값으로 기본 인덱스 열(column_name)을 업데이트합니다. @i:=@i 1 표현식은 행이 업데이트될 때마다 @i를 자동으로 증가시킵니다.

예:

<code class="sql">SET @i=0;
UPDATE table_name SET column_name=(@i:=@i+1);</code>

이 방법은 기본 키 값을 1부터 효율적으로 재할당합니다. 추가 테이블 생성 또는 데이터 이동이 필요합니다. 또한 인덱스 연속성을 보장하면서 원래 데이터 순서를 유지합니다.

위 내용은 임시 테이블 없이 MySQL 기본 인덱스 번호를 다시 매기는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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