首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL重新设置auto_increment值

需求描述 通常,我们都会在数据库表中设置一个增字段作为主键,该字段的值会随着添加新记录而增。 同时也必须注意,这个增字段的值只会一直增加,即使把记录删除了,该自增字段的值也不会变小。...处于某种目的,如果希望该自增字段值一定是连续的,有2种解决办法: 1.表记录不允许物理删除 2.物理删除表记录后重新设置auto_increment 在此,专门针对重新设置auto_increment...为了使得新添加的记录增ID再次继续从50003开始计数,执行如下语句: mysql> alter table 表名 AUTO_INCREMENT=50002; 最后总结 直接修改auto_increment...【参考】 https://blog.csdn.net/hehaoyang666/article/details/41281113 mysql增ID起始值修改方法 https://blog.csdn.net.../fdipzone/article/details/50421831 MySql查看与修改auto_increment方法

1.7K20

mysql 主键增语句_MySQL 增主键

增主键的单调性 为何会有单调性的问题? 这主要跟增主键最大值的获取方式,以及存放位置有关系。 如果最大值是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删除而减小。...MySQL 5.7 及之前的版本,增主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...除非设置了外键。 比如我要向最大一个 ID 的账号充了 100 万。但是在充值之前,该账号被删除,然后服务器故障重启,重启后有人新注册了一个账号。结果我的 100 万充到了他的新账号上。...从 MySQL 8.0 开始,增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...参考文档 为什么 MySQL增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

10.8K10

数据库中设置列字段增(Oracle和Mysql

--这是最简单的一种序列的创建方式,指定了序列从1开始,每次使用后都增1 drop sequence seq_stu; --删除序列(seq_stu为序列名) 2、增数据的插入(序列名.nextval...) insert into stu(stu_id) values(seq_stu.nextval) 如何重置数据表中增 1、删除该序列,再重新创建该序列即可 2、 truncate table...表名; 注意:截断表,即删除所有数据,只保留表结构 Mysql 创建表时直接制定增列/字段 1、通过点击点击相关表选择“设计表”进行设置 ?...2、在建表语句中直接设置(通过auto_increment关键字设置) create table emp( emp_id int primary key auto_increment, emp_name...TRUNCATE TABLE 表名; 注意:会删除表中的数据,只有在MySQL中,TABLE字段可省略

7.2K20

mysql主键增策略_MySQL 增主键机制

对于MyISAM引擎,增值保存在数据文件中; b. Innodb引擎,mysql5.7之前,增值保存在内存中,而且不会持久化增值。...每次重启后第一次打开表,都会去查找增值的最大值max(id), 并设置表当前增值为max(id) + 1; mysql8.0, 增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的值...增值修改策略? a. 在插入时如不指定或指定为0,null,则使用当前的增值填到增字段;并设置当前增值=当前增值+auto_increment_increment 步长; b....增值修改发生在插入数据的操作之前,如果插入失败,增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少增id锁带来的性能影响,mysql不会修改回去之前的增值; 4....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请增 id 的策略(注:该策略是导致增 id 不连续的第三种原因

9.4K50
领券