码迷,mamicode.com
首页 > 数据库 > 详细

【mysql】使数据表ID连续的两个方法

时间:2014-09-10 21:01:41      阅读:226      评论:0      收藏:0      [点我收藏+]

标签:ar   for   数据   div   问题   sp   c   ad   数据库   

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

 

方法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

【mysql】使数据表ID连续的两个方法

标签:ar   for   数据   div   问题   sp   c   ad   数据库   

原文地址:http://www.cnblogs.com/bushe/p/3965129.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!