tom*_*umb 4 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;
Run Code Online (Sandbox Code Playgroud)
我按此顺序运行脚本,因为我没有一个不是主键的自动递增列.
(MySQL 5.3)
Sab*_*lik 11
尝试创建列,将其设置为主键并一次性自动增量
ALTER TABLE `the_table` ADD `new_field` INT NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST;
Run Code Online (Sandbox Code Playgroud)