如何重置MySQL的自动增量列

如何重置MySQL的自动增量列,第1张

你的数据库表可以定义为数字自动递增的主键,MySQL将采取照顾其独特的价值,同时插入新行。

每次添加一个新行,MySQL的增量值自动,它坚持以表。但有时你可能需要重置AUTOINCREMENT列值1。说你写一个示例应用程序,你已经有几行插入表中。现在要删除这些行,并自动增量列复位,使新行插入将有主键的值1 1。

有几个方法来实现这一点。

1。直接复位自动增量值

ALTER TABLE语法提供了一种方法来重新设置自动增量列。采取看看下面的例子。

ALTER TABLE table_name AUTO_INCREMENT = 1;

请注意,你不能重置计数器的值小于或等于任何已使用的。对于MyISAM,如果该值小于或等于目前在AUTO_INCREMENT列的最大值,该值是目前最大的加一复位。对于InnoDB,如果该值大于当前列中的最大值,没有出现错误和不改变当前序列值。

2。截断表截断表自动增量值自动复位为0。

TRUNCATE TABLE table_name;

谨慎使用。用于截断时,任何的AUTO_INCREMENT计数器复位到零。从MySQL 5013上,AUTO_INCREMENT计数器复位为零的TRUNCATE TABLE,而不管是否有一个外键约束。

一旦发射TRUNCATE是,表处理不记得过去使用的AUTO_INCREMENT值,但从头开始计数。这是真实的,甚至对于MyISAM和InnoDB,通常不重用序列值。

3。下降和重新创建表

这是另一种方式下重启自动增量指数。虽然不是很理想。

DROP TABLE table_name;

所有这些技术的价值技术重置自动增量列数。使用任何适合你的要求。

如果数据很重要,有点预算,请用master-slave结构备份,slave机上再用cron做定时备份。

如果数据一般般,或者写入量很少,或者没钱,cron做定时备份就好。

如果数据库全是innodb,可以考虑直接上galera做同步复制,然后slave机上做定时备份。

以上就是关于如何重置MySQL的自动增量列全部的内容,包括:如何重置MySQL的自动增量列、有什么简单的 mysql 增量备份方案、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/9737914.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存