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

MySQL replace into导致的id问题

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

7.1K20

MySQL ID的几个小问题

=4 DEFAULT CHARSET=latin1 ID为4,删除ID最大的记录并不影响ID的值。...MySQL 重启后ID从哪儿开始 例如当前表中有ID为1,2,3三条记录,把3删除,重启MySQL,新插入记录的ID从哪儿开始? 很多人会认为从4开始,实际是从3开始。...手动插入ID后,下次插入增值是多少 例如当前的ID为4,新插入记录时,手动指定ID为10,下次使用增方式插入时,ID是 11。...ID增值 = 当前最大ID + 1 在插入新记录时,就已经计算得出了新的ID值 实验 创建表 tb2,ID: create table tb2(id int unsigned auto_increment...删除最大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

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

PS:当然,在分库分表的场景中,我们通常会使用雪花算法来替代 ID,但中小型项目开发中,使用 ID 的场景还是比较多的。...1.IDMySQL 中,如果字段的数据类型为整数类型(如 INT、BIGINT 等),则可以通过关键字“AUTO_INCREMENT”来设置让当前的字段实现,例如以下 SQL: CREATE...对于按顺序插入的数据,能很好地反映数据插入的先后顺序。1.2 缺点分析 ID 的缺点如下: 在数据进行迁移或分库分表时,可能会出现问题,需要特殊处理。...如果数据量非常大,可能会达到 ID 的上限。 存在安全性问题,比如通过 ID 可能会推测出一些业务信息。...例如,一个电商订单表使用 ID 作为主键,可能会被竞争对手通过订单号大致推测出业务量等信息。2.ID用完会怎样?

11910

MySQLid超大问题查询 转

引言 小A正在balabala写代码呢,DBA小B突然发来了一条消息,“快看看你的用户特定信息表T,里面的主键,也就是id,都到16亿了,这才多久,在这样下去过不了多久主键就要超出范围了,插入就会失败...下图中@1的值对应的是主键id,用(@2, @3)作为唯一索引 ? 后来过了很久,小B给小A指了个方向,小A开始怀疑自己的插入更新语句INSERT ......查了资料之后,小A得知,原来,mysql主键有个参数innodb_autoinc_lock_mode,他有三种可能只0,1,2,mysql5.1之后加入的,默认值是1,之前的版本可以看做都是0。...id是7   delete from t1 where id in (2,3,4);   -- 此时数据表只剩1,5,6了,id还是7   insert into t1 values(2, 106,...删除表的主键 删除主键,让唯一索引来做主键,这样子基本不用做什么变动,只要确定目前的主键没有实际的用处即可,这样的话,插入删除的时候可能会影响效率,但对于查询多的情况来说,小A比较两种之后更愿意选择后者

5K20

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

当我们使用 MySQL 进行数据存储时,一般会为一张表设置一个主键,当有数据行插入时,该主键字段则会根据步长与偏移量增长(默认每次+1)。...的值并不是保存在表结构信息内的,对于不同的版本它们有如下的区别: 1.1.1 MySQL 8.0版本之前(重启后可能会产生变化): 计数器的值存储在内存中的,重启后丢弃,下一次将读取最大的一个ID...该模式下可以保证同一条 insert 语句中新插入ID都是连续的,但如果前一个事务 rollback 丢弃了一部分 ID 的话也会存在后续 ID 出现间隔的情况。...不一定,业务也不应该过分依赖 MySQL ID 的连续性,在以下三种情况下,并不能保证 ID 的连续性: 1.5.1 插入时的其他唯一索引冲突 假设已存在数据{1,张三},且张三所属的字段设置了唯一主键...1.5.3 发生 Bulk Inserts(大量插入)时 发生大量插入时可能会出现ID并不是连续的情况 二、 ID 用完了该怎么办?

3.4K10

mysql 主键语句_MySQL 主键

主键有两个性质需要考虑: 单调性 每次插入一条数据,其 ID 都是比上一条插入的数据的 ID 大,就算上一条数据被删除。...连续性 插入成功时,其数据的 ID 和前一次插入成功时数据的 ID 相邻。 主键的单调性 为何会有单调性的问题? 这主要跟主键最大值的获取方式,以及存放位置有关系。...批量插入中的一部分的 ID 是指定的(非 0 且非 NULL),另一部分未指定,使用数据库生成的 ID。...其他 如果主动指定 ID 为 0 或者 NULL 插入,则会使用数据库生成的 ID。...参考文档 为什么 MySQL主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

10.8K10

如何在MySQL现有表中添加ID

当在MySQL数据库中,ID是一种常见的主键类型,它为表中的每一行分配唯一的标识符。在某些情况下,我们可能需要在现有的MySQL表中添加ID,以便更好地管理和索引数据。...在本文中,我们将讨论如何在MySQL现有表中添加ID,并介绍相关的步骤和案例。图片创建新的ID列添加ID列是在现有表中添加ID的一种常见方法。...添加ID列并填充数据在添加ID列后,我们还需要为现有数据填充ID值。...数据一致性:添加ID列可能需要对现有数据进行更新操作,确保在进行更新之前备份数据,并小心处理可能出现的冲突或错误。结论在本文中,我们讨论了如何在MySQL现有表中添加ID。...通过合理地添加ID列,我们可以更好地管理和索引MySQL表中的数据,提高数据的查询效率和一致性。请记住,在进行任何操作之前,请备份数据并谨慎处理。

1.2K20
领券