mysql 在已存在的表中添加/删除字段约束AUTO_INCREMENT遇到的问题

1. 在已存在的表中添加字段约束AUTO_INCREMENT修饰符

  mysql> alter table user modify uid int auto_increment primary key;
  ERROR 1062 (23000): ALTER TABLE causes auto_increment resequencing, resulting in duplicate entry '1' for key 'PRIMARY'

  理解:uid有0, 而auto_increment是从1开始, 所以修改失败.

  把uid字段的0改成非零后, 再修改添加就可以了:

  mysql>update user set uid=2 where uid=0;

  mysql>alter table user modify uid int auto_increment;

成功!

2. 在已存在的表中删除字段约束AUTO_INCREMENT修饰符

  mysql>alter table user modify uid int;

  如果表中存在其他约束, 如primary key, 依然存在, 需再删除一次约束:

  mysql>alter table user drop primary key;

  注 : 如果primary key和auto_increment同时存在, 需先删除auto_increment, 才能删除primary key.

3. 如果要添加auto_increment, 需先添加primary key

  mysql> alter table user modify uid int auto_increment;

  报错: ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key

  mysql>alter table user add primary key(uid);

  mysql>alter table user modify uid int auto_increment;

posted @ 2019-06-09 10:57  AyeeX  阅读(876)  评论(0编辑  收藏  举报