【问题标题】:MySQL populate new column with incrementing values without auto_incrementMySQL 用不带 auto_increment 的递增值填充新列
【发布时间】:2011-10-13 19:38:34
【问题描述】:

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

我需要在现有表中添加一个自动递增的 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)

【问题讨论】:

    标签: mysql sql auto-increment


    【解决方案1】:

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

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

    【讨论】:

    • 感谢您的提示,但这会导致“SQL 错误 (1068): Multiple primary key defined”
    • @tomfumb 我刚刚给了你create语句,你肯定要删除之前的主键。
    • 添加 SQL "SET @@auto_increment_increment=1;"在那之前,如果你想自动增加 step=1。
    • 我想添加到 ybdesire 的注释中(并且也给予信任)。使用 PHPmyAdmin 4.5.4 在 MySQL 5.0 上为我工作的最终查询: SET @@auto_increment_increment=1; ALTER TABLE my_table_name ADD my_table_field INT NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST;而且效果很好!
    【解决方案2】:

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

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

    【讨论】:

    • MySQL 不允许 auto_increment 列不是主键
    猜你喜欢
    • 2013-07-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-12-08
    相关资源
    最近更新 更多