집 >데이터 베이스 >MySQL 튜토리얼 >자동 증가 필드 기능을 유지하면서 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!