首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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比主库的小,当主从发生切换的时候,这个问题就比较严重了,有些数据写入的时候,就会报错了。

7.1K20
您找到你想要的搜索结果了吗?
是的
没有找到

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.5K20

MySQL ID的几个小问题

=4 DEFAULT CHARSET=latin1 ID为4,删除ID最大的记录并不影响ID的值。...MySQL 重启后ID从哪儿开始 例如当前表中有ID1,2,3三条记录,把3删除,重启MySQL,新插入记录的ID从哪儿开始? 很多人会认为从4开始,实际是从3开始。...tb1 values(null); 删除ID为3的记录: delete from tb1 where id=3 通过上一个问题,我们知道,此时ID值为4。...) 无符号的范围: 0 至 - 1 (0 至 18446744073709551615) 小结 通过实验可以发现InnoDB中ID的一些特性: 插入新记录时,就会计算出新的增值(最大ID+1)...删除最大ID值对ID值没有影响,但MySQL重启之后有影响,不会使用之前的ID值,而是使用最大ID+1,因为ID值是存在内存中,重启后需要重新计算。 ID用完后就不变了。

7.8K21

关于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.6K20

技术分享 | 关于 MySQL ID 的事儿

当我们使用 MySQL 进行数据存储时,一般会为一张表设置一个主键,当有数据行插入时,该主键字段则会根据步长与偏移量增长(默认每次+1)。...的值并不是保存在表结构信息内的,对于不同的版本它们有如下的区别: 1.1.1 MySQL 8.0版本之前(重启后可能会产生变化): 计数器的值存储在内存中的,重启后丢弃,下一次将读取最大的一个ID...不一定,业务也不应该过分依赖 MySQL ID 的连续性,在以下三种情况下,并不能保证 ID 的连续性: 1.5.1 插入时的其他唯一索引冲突 假设已存在数据{1,张三},且张三所属的字段设置了唯一主键...当我们为表设置了主键后, ID 的范围则与主键的数据类型长度相关。...的 API 接口,而用户 ID的,这时会发生什么? 该接口通过简单的尝试就可以暴露出真实的业务用户总数,可以很方便的使用爬虫从1开始递增获取数据信息。

3.5K10

字节面试:MySQLID用完会怎样?

在一些中小型项目开发中,我们通常会使用 ID 来作为主键的生成策略,但随着时间的推移,数据库的信息也会越来越多,尤其是使用 ID 作为日志表的主键生成策略时,可能很快就会遇到 ID 被用完的情况...,那么如果发生了这种情况,MySQL 又会怎样执行呢?...PS:当然,在分库分表的场景中,我们通常会使用雪花算法来替代 ID,但中小型项目开发中,使用 ID 的场景还是比较多的。...1.IDMySQL 中,如果字段的数据类型为整数类型(如 INT、BIGINT 等),则可以通过关键字“AUTO_INCREMENT”来设置让当前的字段实现,例如以下 SQL: CREATE...存在安全性问题,比如通过 ID 可能会推测出一些业务信息。例如,一个电商订单表使用 ID 作为主键,可能会被竞争对手通过订单号大致推测出业务量等信息。2.ID用完会怎样?

11910

mysql 主键语句_MySQL 主键

连续性 插入成功时,其数据的 ID 和前一次插入成功时数据的 ID 相邻。 主键的单调性 为何会有单调性的问题? 这主要跟主键最大值的获取方式,以及存放位置有关系。...MySQL 5.7 及之前的版本,主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...批量插入中的一部分的 ID 是指定的(非 0 且非 NULL),另一部分未指定,使用数据库生成的 ID。...其他 如果主动指定 ID 为 0 或者 NULL 插入,则会使用数据库生成的 ID。...参考文档 为什么 MySQL主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

10.8K10

数据库ID用完了会怎样

我在工作中经常会遇到有人问我,数据库表的ID的,那么如果ID用完了会怎么样?...说实话,我一直从事的是政企行业的开发,因为是传统行业,并且数据量基本上增长缓慢,所以到目前为止我还没遇到过ID用完的情况。因此我连夜做了实验,并编写了这篇文章将结果分享出来。...(全文以MySQL为例,因为MySQL最常用) 一、有主键 在MySQL中int类型占4个字符,因为ID大部分都是以1开始,所以它的取值范围为1到2^32-1,也就是1到4294967295。...首先我们创建一张表,并设置ID,且从2147483647开始。...从这里得知,在有主键且主键的情况下,ID达到上限后MySQL会报错。

76510

线上MySQLid用尽怎么办?

作者:废柴程序员 链接:https://www.jianshu.com/p/a6bc14005b52 MySQLid都定义了初始值,然后不断加步长。...比如,无符号整型(unsigned int)是4个字节,上限就是2^32 - 1。那id用完,会怎么样?...InnoDB系统row_id 若你创建的InnoDB表未指定主键,则InnoDB会自动创建一个不可见的,6个字节的row_id。...所以应该在InnoDB表中主动创建主键:当表id到达上限后,再插入数据时会报主键冲突错误。 毕竟覆盖数据,就意味着数据丢失,影响数据可靠性;报主键冲突,插入失败,影响可用性。...因为MySQL使用了一个唯一数组 图片 给新线程分配thread_id时的逻辑: 图片 总结 每种id有各自的应用场景,在达到上限后的表现也不同: 表的id达到上限后,再申请时它的值就不会改变

3.9K20

线上MySQLid用尽怎么办?

MySQLid都定义了初始值,然后不断加步长。虽然自然数没有上限,但定义了表示这个数的字节长度,计算机存储就有上限。...比如,无符号整型(unsigned int)是4个字节,上限就是2^32 - 1。那id用完,会怎么样?...InnoDB系统row_id 若你创建的InnoDB表未指定主键,则InnoDB会自动创建一个不可见的,6个字节的row_id。...所以应该在InnoDB表中主动创建主键:当表id到达上限后,再插入数据时会报主键冲突错误。 毕竟覆盖数据,就意味着数据丢失,影响数据可靠性;报主键冲突,插入失败,影响可用性。...因为MySQL使用了一个唯一数组 给新线程分配thread_id时的逻辑: 总结 每种id有各自的应用场景,在达到上限后的表现也不同: 表的id达到上限后,再申请时它的值就不会改变,进而导致继续插入数据时报主键冲突错误

3.2K10
领券