mysql重启后自增字段会重置吗(mysql重启后自增字段会重置吗)

mysql重启后自增字段会重置吗(mysql重启后自增字段会重置吗)

扫码添加渲大师小管家,免费领取渲染插件、素材、模型、教程合集大礼包!

大家好,今天来介绍mysql重启后自增字段会重置吗(mysql重启后自增字段会重置吗)的问题,以下是渲大师小编对此问题的归纳和整理,感兴趣的来一起看看吧!

mysql restart 后自增id怎么变了

数据库燃森:mysql
我们的数皮山亩据库表中经常会使用id自增,但是每次清空表后id并不是从1开始计数,总是接着之前的进行自增,那么解决呢?
使用mysql的truncate命令,用法:truncate table 表唯尘名;
这样表的id自增就会变回从1开始自增了

mysql重启后自增字段会重置吗(mysql重启后自增字段会重置吗)

面试官:mysql重启后自增id是从几开始增加

在mysql中用自增列作为主键时,先往表里插入5条凳喊数据,此时表里数据id为1、2、3、4、5,如果此时删除id=4、5的数据后,再重启数据库,重启成功后向表里插入数据的时候,innodb、myisam引擎下ID分别是从几开始增加? 如果你没经历过,或者当面试时被问到这个问题时,相信多数人都是一脸懵逼。MD 谁有事没事去重启线上数据库嘛。最主要的是很多没有测试过这个场景,没有这方面的经验,我在这里做个笔记,大家轻喷!

MySQL 通常使用的引擎都是 INNODB,在建表时,一般使用自增列作为表的主键,这样的表对提高性能有一定的帮助。但是自增列有一个坑,并且这个坑存在了很久,一直到 MySQL 8.0 版本,才修复了这个坑,这个坑就是表的自增列变量 auto_increment 在 MySQL 重启后,有可能丢失。

在 MySQL 低版本中,InnoDB 表中使用自增的 auto-increment 计数器 会把值存放在内存中,不会写入磁盘。一旦 MySQL 服务重启,这个值就丢了,InnoDB 引擎会根据表中现有的数据重新计算该计数器的值:获取表中最大的敬粗山自增主键 ID 作为auto-increment 计数器的最大计数,当 insert 数据时,在 auto-increment 计数器最大值上 1。

先创建一张 user 表,新增几条数据:

向 user 表里插入 5 条数据,主键 ID 按自增列通过 auto-increment 计数器实现自增。

在 user 表里删除 id 为 4、5 的数据,再向 user 表中插入一条数据,主键 ID 是 auto-increment 的值 6。

mysql 数据库重启后,innodb 自增主键 ID 会根据 auto-increment 计数器的重置而重置。

在场景一的基础上,在删除 id 为 6、3 的数据后,此时 auto-increment 计数器的值为 7,user 表里的 id 最大是 2。

然后重启数据库后,auto-increment 计数器的值变为 3,也就是 user 表里的自增列 ID 的最大值 2 加 1。

此时在插入数据时,自增 ID 会从 3 开始自增。Innodb 表中把自增列作为主键 ID 时,在 mysql 重启后就会存在 ID 重置问题。删除数据后,再重启,AUTO_INCREMENT 会查询表里最大 ID 并进行重置,重置后和重启前AUTO_INCREMENT 计数器的值不同。在 MyISAM 引擎表中的自增列不会存在这个问题。

在 MySQL 8.0 中,这个计数器的逻辑变了:每当计数器的值有变,InnoDB 会将其写入 redo log,保存到引擎专用的系统表中。MySQL 正常关闭后重启:从系统表中获取计数器的数值。MySQL 故障后重启:从系统表中获取计数器的值;从最后一个检查点开始扫描 redo log 中记录的计数器值;取这两者的最大值作为新值。

总结

如果 mysql 重启了,那么 innodb 表在启动后,AUTO_INCREMENT 会自动检测出、并重置为当前表中自增列的最大值 +1。2)假如一个表格里 AUTO_INCREMENT 计数器的值是 10,此时执行update table set id = 15 where id = 9后,如果这时再继亮中续插入数据,到了自增 ID=15 的时候是会报错。但是这个时候继续插入,就不会报错。因为刚才即使报错了,AUTO_INCREMENT 的值依旧会增加。3)现在使用的一般都是 innodb 引擎,如果将 myisam 引擎转换过来的时候,一定要小心这个引擎在自增 id 上的不同表现。在主从使用不同引擎的时候,也会出现问题,最好将引擎改完一致性的。

如何重置MySQL的自动增量列_MySQL

bitsCN.com
如何重置MySQL的自动增量列
MySQL数据库提供了一个奇妙的功能AUTOINCREMENT列指数。你的数据库表可以定义为数字自动递增的主键,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 5.0.13上,AUTO_INCREMENT计数器复位为零的TRUNCATE TABLE,而不管是否有一备数派个外键约束。
一旦发射TRUNCATE是,表处理不记得过去使用的AUTO_INCREMENT值,但从头开始计数。这是真实的,甚至对于MyISAM和InnoDB,通常不重用序列值。
3。下降和重新创建表
这是另一种方式下重启自动增量指数。虽然不是很理想。
DROP TABLE table_name;
CREATE TABLE table_name { ... };
所有这些技术的价值技术重置自动增量列数。使用任何适合你的要求。
bitsCN.com

怎么重置mysql的自增列AUTO

重置自增列会腔携删除原有数据。
1.支持设置自增列的值

ALTER TABLE table_name AUTO_INCREMENT = 1;

不过这种方式自能设置大于当前使用伍缺伏的值,不能设置小于等于当前已经使用的自增列的值。myisam如果设置小于等于,则自增列的值会自动设置为
当前最大值加1。innodb则不会改变。

2.通过TRUNCATE把自增列设置为0,从MySQL 5.0.13开始TRUNCATE就扮尺能重置自增列为0.myisam和innode都是如此。

TRUNCATE TABLE table_name;

3.drop和create重建表方式重置自增列为0

DROP TABLE table_name;
CREATE TABLE table_name { ... };

如何重置MySQL中表中自增列的初始值的实现方法分享

这篇文章主要介绍了重置MySQL中表中自增列的初始值的实现方法的相关资料,需要的朋友可以参考下
重置MySQL中表中自增列的初始值的实现方法
1. 问题的提出
在MySQL的数据库设计中,一般都会设计自增的数字列,用作业务无关的主键。 在数据库出现频繁的删除操作或者清空操作之后,其自增的值仍然会自动增长,如果需要重新开始该如何做呢?
2. 解决办法
a. alter table
delete from table_name;
ALTER TABLE table_name AUTO_INCREMENT = 1; 如果数据库表中的数据很多,则删除操作会持续比较久,这个问题需要注橡模意。

b. truncate
truncate table_name 简单快捷,直接清空数据。袜团

3. delete vs tuncate
主要的区别如下:
truncate速度快,不做日志记录,故无法进行rollback操作。 delete反之。
truncate会重置索引和自增初始值, delete则不会告如橘
truncate不会触发trigger,而delete则会触发。

分享到 :
相关推荐

saber插件怎么加在形状图层(saber光效怎么沿着路径循环)

1、saber插件怎么加在形状图层Saber是一款强大的插件,可用于在形状图层上创[...

wifi漫游是什么意思(小翼管家wifi漫游有必要开吗)

1、wifi漫游是什么意思WiFi漫游是指使用匿名接入(AA)技术,使用户能够在不[...

ps选择主体在哪里(ps选择主体是哪个版本才有的功能)

1、ps选择主体在哪里PS选择主体在哪里?PS(Photoshop)是一款功能强[&...

如何打印测试页(佳能g3800如何打印测试页)

1、如何打印测试页如何打印测试页打印测试页是我们在日常使用打印机时常常需要做的一[&...

发表评论

您的电子邮箱地址不会被公开。 必填项已用*标注