MySQL使用递增值填充新列而不使用auto_increment

时间:2011-07-26 22:21:09

标签: mysql sql auto-increment

我看到很多几乎相似的问题有明显的答案,但我很确定这个问题还没有在这里。

我需要将一个自动递增的id列添加到现有表中,并将其设置为主键。我不能丢失任何现有数据。

我可以成功更改表结构,但是我在新列中收到有关截断数据的错误。当我查看数据时,新的自动递增列中的每个值都为空(因此不是唯一的)。

如何回填这些值以确保主键的唯一性?

***如果有更简单的解决方案,我宁愿避免将现有数据转储到临时表中并重新插入。

当前脚本:

alter table the_table add new_field int first;
alter table the_table drop primary key, add primary key (new_field);
alter table the_table change new_field new_field int unsigned not null auto_increment;

我按此顺序运行脚本,因为我没有一个不是主键的自动递增列。

(MySQL 5.3)

2 个答案:

答案 0 :(得分:11)

尝试创建列,将其设置为主键并一次性自动递增

ALTER TABLE `the_table` ADD `new_field` INT NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST; 

答案 1 :(得分:0)

只需添加一个自动增量字段,而不是主键:

ALTER TABLE `the_table` ADD `new_field` INT NOT NULL AUTO_INCREMENT