>데이터 베이스 >MySQL 튜토리얼 >자동 증가 필드 기능을 유지하면서 MySQL의 기본 키를 수정할 수 있습니까?

자동 증가 필드 기능을 유지하면서 MySQL의 기본 키를 수정할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-29 19:18:02604검색

Can I Modify the Primary Key in MySQL While Keeping an Auto-Incrementing Field Functional?

MySQL 기본 키 수정: 자동 증가와 쿼리 효율성의 균형

MySQL에서 테이블을 정의할 때 자동 증가 필드를 다음과 결합하려고 할 때 일반적인 문제가 발생합니다. 다른 키를 기본 키로 사용합니다. 이 문서에서는 최적의 성능과 식별자 접근성을 유지하면서 이를 달성하는 방법에 대한 문제를 다룹니다.

제공된 테이블 예제에는 자동 증가 ID 필드와 쿼리에서 멤버를 식별하는 데 사용되는 고유한 memberid 필드가 있습니다. id 필드의 자동 증가 기능을 유지하면서 memberid를 기본 키로 설정하는 방법에 대한 의문이 생깁니다.

오류 "1075 - 잘못된 테이블 정의; 자동 열은 하나만 있을 수 있으며 정의해야 합니다. 키로"는 MySQL에서 자동 증가 열을 키로 정의해야 함을 나타냅니다. 이 문제를 해결하려면 id 필드에 인덱스(키)를 추가해야 합니다.

다음 수정된 테이블 정의는 문제를 해결합니다.

CREATE TABLE members (
  id int(11)  UNSIGNED NOT NULL AUTO_INCREMENT,
  memberid VARCHAR( 30 ) NOT NULL ,
  `time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ,
  firstname VARCHAR( 50 ) NULL ,
  lastname VARCHAR( 50 ) NULL ,
  PRIMARY KEY (memberid),
  KEY (id)                          --- or:    UNIQUE KEY (id)
) ENGINE = MYISAM;

id 필드에 인덱스를 생성하여, MySQL은 id 또는 memberid 필드를 사용하여 레코드를 효율적으로 찾을 수 있습니다. 이 솔루션은 자동 증가 ID 필드의 이점을 유지하면서 memberid를 사용하는 쿼리 성능이 저하되지 않도록 보장합니다.

따라서 자동이 아닌 기본 키로 데이터베이스 테이블을 구성하는 것이 가능합니다. -자동 증가 열의 기능과 효율성을 유지하면서 필드를 증가시킵니다. 테이블 디자인의 이러한 유연성은 쿼리에서 최적의 성능과 사용자 친화적인 식별자 사용을 가능하게 합니다.

위 내용은 자동 증가 필드 기능을 유지하면서 MySQL의 기본 키를 수정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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