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,145 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

Complete Microsoft Windows PC® & Mac Backup

Backup and recovery solutions to protect all your PCs & Mac– on-premises or in remote locations. Acronis backs up entire PC or Mac with patented reliable disk imaging technology and you will be able to restore workstations to a new, dissimilar hardware in minutes.

Join & Write a Comment

Introduction In this article, I will by showing a nice little trick for MySQL similar to that of my previous EE Article for SQLite (http://www.sqlite.org/), A SQLite Tidbit: Quick Numbers Table Generation (http://www.experts-exchange.com/A_3570.htm…
Foreword This is an old article.  Instead of using the MySQL extension that was used in the original code examples, please choose one of the currently supported database extensions instead.  More information is available here: MySQLi / PDO (http://…
Access reports are powerful and flexible. Learn how to create a query and then a grouped report using the wizard. Modify the report design after the wizard is done to make it look better. There will be another video to explain how to put the final p…
This video demonstrates how to create an example email signature rule for a department in a company using CodeTwo Exchange Rules. The signature will be inserted beneath users' latest emails in conversations and will be displayed in users' Sent Items…

706 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

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now