大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说关于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:[email protected]+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
===============================
新建查询:
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顺序不连续的解决方法
原文地址:https://www.cnblogs.com/apolloren/p/13375063.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/7100.html