> 데이터 베이스 > MySQL 튜토리얼 > MySQL 오류 #1071: 지정된 키가 너무 깁니다.가 발생하는 이유는 무엇입니까?

MySQL 오류 #1071: 지정된 키가 너무 깁니다.가 발생하는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-28 07:41:42
원래의
388명이 탐색했습니다.

Why Am I Getting MySQL Error #1071: Specified Key Was Too Long?

MySQL 오류 #1071: 키 길이 제한 이해

특정 열(column1 및 column2)이 있는 테이블에 고유 인덱스를 추가하려고 할 때 ), 사용자에게 다음 오류가 발생할 수 있습니다.

#1071 - Specified key was too long; max key length is 767 bytes
로그인 후 복사

처음에는 컬럼1(20)과 컬럼2(500)의 합산 길이는 최대 키 길이인 767바이트 내에 있으며, 실제 설명은 MySQL의 프리픽스 인덱싱 제한을 이해하는 데 있습니다.

MySQL 5.7 이전 버전에서는 InnoDB 테이블에 접두사 인덱스 제한은 767바이트인 반면 MyISAM 테이블은 1,000바이트로 더 큰 제한이 있습니다. 이는 인덱스에 사용되는 최대 바이트 수가 인덱스에 포함된 열의 시작 부분을 기반으로 함을 의미합니다.

주어진 예에서 컬럼 1과 컬럼 2는 모두 VARCHAR(x) 컬럼입니다. , 가변 길이 문자열을 저장합니다. 이 오류는 MySQL이 저장된 실제 데이터뿐만 아니라 열의 전체 길이를 인덱스의 일부로 간주하기 때문에 발생합니다. 결과적으로, 컬럼1과 컬럼2의 실제 데이터가 전체 할당 길이보다 짧더라도 인덱스 크기는 최대 한도를 초과합니다.

이 오류를 방지하려면 사용자에게 다음과 같은 몇 가지 옵션이 있습니다.

  • VARCHAR 열 길이 제한: VARCHAR 길이에 대한 하한을 설정하면 인덱스 크기가 maximum.
  • 열의 일부만 인덱스화: 인덱스 정의에서 각 열 문자의 하위 집합(예: 컬럼1(15) 및 컬럼2(200))만 지정합니다. 이렇게 하면 전체 인덱스 크기가 줄어들고 인덱스를 생성할 수 있습니다.
  • 데이터 모델 검토를 고려하세요. 키 길이 제한을 초과하지 않고 비즈니스 규칙을 구현하는 대체 방법을 살펴보세요. 여기에는 데이터를 여러 열로 분할하거나 추가 테이블을 도입하는 작업이 포함될 수 있습니다.

MySQL 키 길이 오류를 방지하려면 열 길이가 인덱스 크기에 미치는 영향을 이해하는 것이 중요합니다. 열 크기와 인덱스 정의를 주의 깊게 관리함으로써 사용자는 데이터베이스 제한을 초과하지 않고 인덱스를 성공적으로 구현하고 데이터 무결성을 유지할 수 있습니다.

위 내용은 MySQL 오류 #1071: 지정된 키가 너무 깁니다.가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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