我看到很多几乎相似的问题有明显的答案,但我很确定这个问题还没有在这里.
我需要将一个自动递增的id列添加到现有表中,并将其设置为主键.我不能丢失任何现有数据.
我可以成功地更改表结构,但是我在新列中收到有关截断数据的错误.当我查看数据时,新自动递增列中的每个值都为null(因此不是唯一的).
如何回填这些值以确保主键的唯一性?
***我宁愿避免将现有数据转储到临时表,如果有更简单的解决方案,则重新插入.
当前脚本:
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)
解决方法:
尝试创建列,将其设置为主键并一次性自动增量
ALTER TABLE `the_table` ADD `new_field` INT NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST;
标签:mysql,sql,auto-increment 来源: https://codeday.me/bug/20190716/1482505.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。