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의 실제 데이터가 전체 할당 길이보다 짧더라도 인덱스 크기는 최대 한도를 초과합니다.
이 오류를 방지하려면 사용자에게 다음과 같은 몇 가지 옵션이 있습니다.
MySQL 키 길이 오류를 방지하려면 열 길이가 인덱스 크기에 미치는 영향을 이해하는 것이 중요합니다. 열 크기와 인덱스 정의를 주의 깊게 관리함으로써 사용자는 데이터베이스 제한을 초과하지 않고 인덱스를 성공적으로 구현하고 데이터 무결성을 유지할 수 있습니다.
위 내용은 MySQL 오류 #1071: 지정된 키가 너무 깁니다.가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!