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

增主键竟然不是连续递增

很多低级开发工程师都想当然觉得增主键是严格连续递增的,但事实真的如此吗?...假设事务 B 稍后于 A 事务A 事务B 申请到id=2 申请到id=3 此时表t的增值4 此时表t的增值4 正确提交了 唯一键冲突 若允许A把id回退,即把t的当前增值改回2,则:...表里已有id=3,而当前id值是2。...之所以走进如此的怪圈,就因为“允许id回退”这个前提的存在。 所以InnoDB放弃这样的设计,语句即使执行失败了,也不回退id! 所以id只保证是递增的,但不保证是连续的!...id,会分配4个 依此类推,同一个语句去申请id,每次申请到的id个数都是上一次的两倍。

3.4K10

增主键竟然不是连续递增

很多低级开发工程师都想当然觉得增主键是严格连续递增的,但事实真的如此吗?...假设事务 B 稍后于 A 事务A 事务B 申请到id=2 申请到id=3 此时表t的增值4 此时表t的增值4 正确提交了 唯一键冲突 若允许A把id回退,即把t的当前增值改回2,则:...表里已有id=3,而当前id值是2。...之所以走进如此的怪圈,就因为“允许id回退”这个前提的存在。 所以InnoDB放弃这样的设计,语句即使执行失败了,也不回退id! 所以id只保证是递增的,但不保证是连续的!...id,会分配4个 依此类推,同一个语句去申请id,每次申请到的id个数都是上一次的两倍。

2.6K00

id用完怎么办

我们知道mysql中存在很多id,然后不断增长,由于只要给id定义了这个数的字节长度,那么他就有了上限,比如无符号整型(unsigned int)是4个字节,因此他的上限是2^32-1, 表定义增值...id 表定义的增值达到上限后的逻辑是,在申请下一个id时,得到的值保持不变....8个字节的bigint unsigned InnoDB系统增row_id 如果你创建的InnoDB表没有指定主键,那么InnoDB会给你创建一个不可见的,长度为6字节的row_id,InnoD维护了一个...max_trx_id+1,因此一个事物中至少加2,还有就是innoDB的后台操作,比如表达索引信息统计这个类也是会启动内部事务的因此可以看到,trx_id值并不是按照加1递增的 现在我们看看为什么T2...thread_id 线程id是我们最常见的一种id,我使用show processlist的第一列计数就是thread_id, thread_id的逻辑很好理解,系统保存一个全局变量thread_id_conuter

1K20

分布式ID算法Snowflake

但是数据迁移后我们遇到一个问题,之前mysql数据库中,我们采用的是id主键,可选用的tidb又对增主键不是很友好,所以我们选用了另一种主键生成方式:Snowflake算法。...算法原理 SnowFlake算法是Twitter设计的一个可以在分布式系统中生成唯一的ID的算法,它可以满足每秒上万条消息ID分配的请求,这些消息ID是唯一的且有大致的递增顺序。...优缺点 优点: 01 趋势递增:毫秒数在高位,序列号在低位 02 性能高无单点:本地计算不依赖数据库等第三方 03 使用灵活:三个组成部分的位数可按需求调整 缺点: 01 序列不连续 02 无法控制生成规则...= 5 worker_id_bits = 15 sequence_id_bits = 2 max_datacenter_id = 1 << datacenter_id_bits max_worker_id...sid += sequence_id % max_sequence_id 效果 采用Snowflake算法后,数据id可以保持时间递增并且全局唯一。

73820

id用完了怎么办

id用完了怎么办 阅读本文大概需要2分钟 1. 表定义id 我们通常会把主键设置成id,主键id的最大值是 (bigint unsigned)。...InnoDB系统增row_id 如果创建的表使用InnoDB引擎,但是没有指定主键的话。InnoDB会创建一个不可见,长度为6个字节的row_id。...InnoDB维护了一个全局变量dict_sys.row_id,所有无主键的InnoDB表,每插入一行数据,会将当前时刻的dict_sys.row_id 赋值给row_id,然后增1。...row_id 的上限是 ,row_id 达到上限后,会归0,然后重新循环,则新插入的数据会覆盖之前的数据(如果row_id一致)。 3. InnoDB trx_id trx_id, 事务id。...InnnoDB内部维护max_trx_id全局变量,每次申请trx_id 获取当前的max_trx_id 然后会将max_trx_id 加1。

98220

MySQL ID的几个小问题

=4 DEFAULT CHARSET=latin1 ID为4,删除ID最大的记录并不影响ID的值。...手动插入ID后,下次插入时增值是多少 例如当前的ID为4,新插入记录时,手动指定ID为10,下次使用增方式插入时,ID是 11。...ID增值 = 当前最大ID + 1 在插入新记录时,就已经计算得出了新的ID值 实验 创建表 tb2,ID增: create table tb2(id int unsigned auto_increment...ID的一些特性: 插入新记录时,就会计算出新的增值(最大ID+1),不管是使用自动ID,还是手动指定一个ID。...删除最大ID值对ID值没有影响,但MySQL重启之后有影响,不会使用之前的ID值,而是使用最大ID+1,因为ID值是存在内存中,重启后需要重新计算。 ID用完后就不变了。

7.7K21

MySQL replace into导致的id问题

// MySQL replace into导致的id问题 // 今天线上遇到一个问题,挺有意思,这里记录一下希望对大家有所帮助。...某个表中,只有一条记录,发生高可用切换之后,id的值发生了变化,主从的id值不一致,导致数据写入报主键冲突的错误。...=3,age=3这条记录,然后插入id=6,age=3这条记录,增值变为7....*/; 可以看到,MySQL将replace into的在binlog中保存的格式是update语句,那么update语句本质上不会对增值进行修改,所以就导致了主从的表id不一致,这样虽然看着没有什么问题...,从库的id比主库的小,当主从发生切换的时候,这个问题就比较严重了,有些数据写入的时候,就会报错了。

6.9K20

MySQL 主键 ID 会用完吗?

MySQL 主键 ID 会用完吗?...首先我们一般创建 MySQL 数据表的时候,大部分情况下会创建一个增主键ID 的字段,可能你的建表语句如下: CREATE TABLE IF NOT EXISTS `tb`( `id` INT...所以 在 MySQL 中 ID 是会用完的。那么问题来了,加入他的 ID 用完会发生什么事呢? 我们来验证下。...如果会那么久需要创建 8 字节的 INT 类型了,他的值最大是 2^64-1 那么问题又来了,你说 我有些业务是不需要主键 、不需要增编号,我不创建这个字段,就好了,这样想恭喜你 回答错误....总结: ID 用完 会报主键冲突、数据插入失败。 不指定主键、默认创建的 row_id 会 覆盖原有的数据。

9.4K20

MySQLid超大问题查询 转

小A又仔细观察了这1000多万已有的数据,将插入时间、id作为主要观察字段,很快,发现了个问题,每天第一条插入的数据总是比前一天多1000多万,有时候递增的多,有时候递增的少,小A又将矛头指向了DBA小...下图中@1的值对应的是增主键id,用(@2, @3)作为唯一索引 ? 后来过了很久,小B给小A指了个方向,小A开始怀疑自己的插入更新语句INSERT ......id是7   delete from t1 where id in (2,3,4);   -- 此时数据表只剩1,5,6了,id还是7   insert into t1 values(2, 106,... "test1"),(NULL, 107, "test2"),(3, 108, "test2");   -- 这里的id是多少呢? ...上面的例子执行完之后表的下一个id是10,你理解对了吗,因为最后一条执行的是一个Mixed-mode inserts语句,innoDB会分析语句,然后分配三个id,此时下一个id就是10了,但分配的三个

4.9K20

关于mysqlid的获取和重置

缺点:获取的不是真正的id,是表中最大的Id,如果有删除数据的话,那么该值和id相差比较大。如果有连表数据,有可能导致数据错乱。...使用LAST_INSERT_ID函数:select LAST_INSERT_ID() 优点:获取到的是真正的id。 缺点:该函数是与table无关的,永远保留最新插入的增列的id。...使用mysql查询函数:SHOW TABLE STATUS; 优点:能够准确的查到id。而且可以在语句后面加上where语句或者like语句来过滤。...---- mysqlid的重置 使用truncate:truncate table; 说明:使用truncate会删除表的数据释放空间,并且重置字id,但不会删除表的定义。...也不会清空数据,有可能会出现重复key的可能,所以此方法也只适用于清空表之后重置id或者大量删除后修改自增id

11.3K20
领券