关于mysql删除记录后id顺序不连续的解决方法

Posted 阿波罗任

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于mysql删除记录后id顺序不连续的解决方法相关的知识,希望对你有一定的参考价值。

经常有一些完美主义者问我,怎么让数据库的自增字段在记录被删除时重置它们的顺序,这里不去讨论这么折腾是否真有必要,只说说解决方法,有这方面需求的朋友不妨看看。

 

方法1、删除自增字段,然后重建(缺点就是必须记住自增字段的其它属性,不然可能会导致一些未知问题)

ALTER TABLE `tablename` DROP COLUMN `id`;

ALTER TABLE `tablename` ADD `id` int(10) unsigned NOT NULL AUTO_INCREMENT FIRST,ADD PRIMARY KEY (`id`), AUTO_INCREMENT = 0 ROW_FORMAT = COMPACT;

 

方法2、通过sql语句按顺序重置自增字段值,实现方法:

SET @i=0;

UPDATE `tablename` SET `id`=(@i:=@i+1);

ALTER TABLE `tablename` AUTO_INCREMENT=0

 

 

自测方法2完美!!

 
========================

mysql的user表中本来15条数据,我把后5条给删除了,再插入新用户后id会从16开始计数, 导致重新插入值,字段id取值不连续.

 

 

 

解决方案:

ALTER TABLE USER AUTO_INCREMENT=10;  (此处10改为自己的断点即可)

 

再插入新数据id就连上了,eg:

 


————————————————
版权声明:本文为CSDN博主「wudinaniya」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/wudinaniya/java/article/details/77606288

===============================

数据库当中删除数据后主键id不连续的问题

 

新建查询:

ALTER TABLE `表名` DROP `主键名`;
ALTER TABLE `表名` ADD `主键名` int NOT NULL FIRST;
ALTER TABLE `表名` MODIFY COLUMN `主键名` int NOT NULL AUTO_INCREMENT,ADD PRIMARY KEY(主键名);

回到数据库刷新一下啊,这样就ok啦!

 
分类: 科技苍穹

以上是关于关于mysql删除记录后id顺序不连续的解决方法的主要内容,如果未能解决你的问题,请参考以下文章

mysql-重新排序修改排序值-删除数据后排序字段序号断层,重新根据顺序设置连续性的排序值

mysql中如何查询数据库中id不连续的数据

关于解决织梦文档栏目删除后ID 从1开始的方法

Bug: 删除中间某条记录后/删除最后一条记录再添加 ,auto-increment的自动增长不连续

MySQL自增id不连续问题

MYSQL计算连续与不连续区间的方法