MySQL 5.5 報錯"ERROR 1075 (42000): Incorrect table definition"

feelpurple發表於2016-04-17
--給表增加自增欄位的時候報錯

mysql> desc t7;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| name  | varchar(20) | YES  |     | NULL    |       |
| id    | int(4)      | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> alter table t7 add id2 int(4) auto_increment;
ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key

報錯原因:自增欄位沒有被定義為一個key。

解決辦法:可以將新增欄位定義為unique key或primary key。

mysql> alter table t7 add id2 int(4) auto_increment primary key;
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table t7 drop column id2;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table t7 add id2 int(4) auto_increment unique key;
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26506993/viewspace-2082626/,如需轉載,請註明出處,否則將追究法律責任。

相關文章