Solved

Incorrect table definition; there can be only one auto column and it must be defined as a key

Posted on 2009-05-04
2
3,189 Views
Last Modified: 2012-05-06
I am attempting to migrate from MS SQL to MYSQL, using the MYSQL Migration Toolkit.  I have generated scripts with the tool that I am running from myPHPadmin.  While some of the CREATE TABLE commands are working, a few of them generate this error:

Incorrect table definition; there can be only one auto column and it must be defined as a key.

My understanding is you cannot have more than one field with auto_increment, and it must be primary key.  Can you not have multiple primary keys but set only one of the to auto_increment?


DROP TABLE IF EXISTS `captain1`.`tblEducation`;
CREATE TABLE `captain1`.`tblEducation` (
  `UserID` INT(10) NOT NULL,
  `EducationID` INT(10) NOT NULL AUTO_INCREMENT,
  `InstituteName` VARCHAR(50) NULL,
  `ProgramName` VARCHAR(50) NULL,
  `LevelObtained` VARCHAR(50) NULL,
  `StudyFrom` DATETIME NULL,
  `StudyTo` DATETIME NULL,
  `GradDate` DATETIME NULL,
  `Skills` VARCHAR(50) NULL,
  `Type` VARCHAR(50) NULL,
  PRIMARY KEY (`UserID`, `EducationID`),
  CONSTRAINT `FK_tblEducation_tblUsers` FOREIGN KEY `FK_tblEducation_tblUsers` (`UserID`)
    REFERENCES `captain1`.`tblUsers` (`UserID`)
    ON DELETE NO ACTION
    ON UPDATE NO ACTION
)
ENGINE = INNODB;

Open in new window

0
Comment
Question by:phisherpryce
2 Comments
 
LVL 28

Assisted Solution

by:gamebits
gamebits earned 200 total points
ID: 24298088
A PRIMARY KEY is a unique index where all key columns must be defined as NOT NULL. If they are not explicitly declared as NOT NULL, MySQL declares them so implicitly (and silently). A table can have only one PRIMARY KEY. If you do not have a PRIMARY KEY and an application asks for the PRIMARY KEY in your tables, MySQL returns the first UNIQUE index that has no NULL columns as the PRIMARY KEY.

More info here

http://dev.mysql.com/doc/refman/5.1/en/create-table.html
0
 
LVL 17

Accepted Solution

by:
k_murli_krishna earned 300 total points
ID: 24298093
Please refer:
http://www.experts-exchange.com/Database/MySQL/Q_24265504.html

You have to make UserID also as an AUTO_INCREMENT column and have the rest definition as it is and the table should get created.
0

Featured Post

Efficient way to get backups off site to Azure

This user guide provides instructions on how to deploy and configure both a StoneFly Scale Out NAS Enterprise Cloud Drive virtual machine and Veeam Cloud Connect in the Microsoft Azure Cloud.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction In this installment of my SQL tidbits, I will be looking at parsing Extensible Markup Language (XML) directly passed as string parameters to MySQL 5.1.5 or higher. These would be instances where LOAD_FILE (http://dev.mysql.com/doc/refm…
More Fun with XML and MySQL – Parsing Delimited String with a Single SQL Statement Are you ready for another of my SQL tidbits?  Hopefully so, as in this adventure, I will be covering a topic that comes up a lot which is parsing a comma (or other…
In an interesting question (https://www.experts-exchange.com/questions/29008360/) here at Experts Exchange, a member asked how to split a single image into multiple images. The primary usage for this is to place many photographs on a flatbed scanner…

839 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question