>  기사  >  데이터 베이스  >  MySQL 오류 코드 #1089 \"잘못된 접두사 키\"가 나타나는 이유는 무엇입니까?

MySQL 오류 코드 #1089 \"잘못된 접두사 키\"가 나타나는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-01 07:35:30272검색

Why Am I Getting MySQL Error Code #1089

MySQL 오류 코드 #1089 이해

MySQL 오류 코드 #1089, "잘못된 접두사 키"는 기본 키에 문제가 있음을 나타냅니다. 또는 고유 인덱스. 특히 사용된 키 부분이 문자열이 아니거나 사용된 키 부분의 길이가 실제 키 부분의 길이를 초과하는 경우에 발생합니다.

제공된 SQL 쿼리에서:

CREATE TABLE `movies`.`movie` (
  `movie_id` INT(3) NULL AUTO_INCREMENT,
  `movie_name` VARCHAR(25) NULL,
  `movie_embedded_id` VARCHAR(50) NULL,
  `rating_no` INT(3) NULL,
  `movie_description` VARCHAR(50) NULL,
  PRIMARY KEY (`movie_id`(3))
) ENGINE = InnoDB;

문제는 PRIMARY KEY(movie_id(3)) 사용으로 인해 발생합니다. 이 줄은 (3) 세그먼트로 지정되는 movie_id 열의 처음 3바이트에 기본 키를 생성합니다.

그러나 숫자 데이터 유형(이 경우 INT)에 접두사를 생성하려고 합니다. MySQL에서는 지원되지 않습니다. 접두사 키는 문자열 기반 데이터 유형에만 적용 가능하기 때문입니다.

오류를 해결하려면 다음 쿼리를 사용해야 합니다.

CREATE TABLE `movies`.`movie` (
  `movie_id` INT(3) NULL AUTO_INCREMENT,
  `movie_name` VARCHAR(25) NULL,
  `movie_embedded_id` VARCHAR(50) NULL,
  `rating_no` INT(3) NULL,
  `movie_description` VARCHAR(50) NULL,
  PRIMARY KEY (`movie_id`)
) ENGINE = InnoDB;

(3) 세그먼트를 제거하여, 기본 키는 접두사가 아닌 전체 movie_id 열에 생성됩니다. 이렇게 하면 문제가 해결되고 MySQL이 기본 키를 올바르게 생성할 수 있습니다.

위 내용은 MySQL 오류 코드 #1089 \"잘못된 접두사 키\"가 나타나는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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