微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 重新索引MySQL INT主键并重置AUTO_INCREMENT

所以我有一个MySQL数据库,我正在使用PHP网站.在几周的发展过程中,我留下了类似的东西:

Table: users

id  | name
-----------
  12| Bob
  34| Jen
 155| John
 154| Kyle

除此之外,还有数百条记录,而且数以千计.

我正在寻找一个脚本,我可以运行将键重命名为最低值(保留各自的行),然后将AUTO_INCREMENT重置为下一个id

期望的输出是:

Table: users

id  | name
-----------
   1| Bob
   2| Jen
   3| Kyle
   4| John

和ALTER TABLE用户AUTO_INCREMENT = 5;

(注意凯尔和约翰)

我意识到我必须修复任何引用users.id的东西.

有没有人知道在MysqLPHP脚本中这样做的方法

解决方法:

删除id上的索引

做这样的事情:

SET @rank:=0;
update users
set id=@rank:=@rank+1
order by id;

在id上添加索引

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐