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

mysql主键策略_MySQL 主键机制

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

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

深入剖析 MySQL

之前的文章把 InnoDB 中的所有的锁都介绍了一下,包括意向锁、记录锁...锁巴拉巴拉的。但是后面我自己回过头去看的时候发现,对锁的介绍居然才短短的一段。...其实锁(AUTO-INC Locks)这块还是有很多值得讨论的细节,例如在并发的场景下,InnoDB 是如何保证该值正确的进行的,本章就专门来简单讨论一下 InnoDB 中的锁。...什么是锁 之前我们提到过,锁是一种比较特殊的表级锁。...行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...基于 MySQL 默认 Binlog 格式从 Statement 到 Row 的变更,InnoDB 也将其锁的默认实现从连续模式,更换到了效率更高的交叉模式。

3.2K40

MySQL主键详解「建议收藏」

不同的引擎对于增值的保存策略不同 1.MyISAM引擎的增值保存在数据文件中 2.InnoDB引擎的增值,在MySQL5.7及之前的版本,增值保存在内存里,并没有持久化。...2 3.将传入的行的值改成(2,1,1) 4.将表的增值改成3 5.继续执行插入数据操作,由于已经存在c=1的记录,所以报Duplicate key error(唯一键冲突),语句返回 对应的执行流程图如下...出现了主键不连续的情况 唯一键冲突和事务回滚都会导致主键id不连续的情况 四、锁的优化 id锁并不是一个事务锁,而是每次申请完就马上释放,以便允许别的事务再申请 但在MySQL5.0版本的时候...也就是说,如果一个语句申请了一个表锁,这个锁会等语句执行结束以后才释放 MySQL5.1.22版本引入了一个新策略,新增参数innodb_autoinc_lock_mode,默认值是1 1.这个参数设置为...0,表示采用之前MySQL5.0版本的策略,即语句执行结束后才释放锁 2.这个参数设置为1 普通insert语句,锁在申请之后就马上释放 类似insert … select这样的批量插入数据的语句,

5.7K40

mysql为什么建议使用主键

前面我写了几篇关于 mysql 索引的文章,索引是 mysql 非常重要的一部分。...我们都知道表的主键一般都要使用 id,不建议使用业务 id ,是因为使用 id 可以避免页分裂。这个其实可以相当于一个结论,你都可以直接记住这个结论就可以了。...如果主键为 id 的话,mysql 在写满一个数据页的时候,直接申请另一个新数据页接着写就可以了。...如果主键是非 id,为了确保索引有序,mysql 就需要将每次插入的数据都放到合适的位置上。...本来这篇文章是打算总结一下前面写的几篇关于 mysql 索引的文章的,也是打算多举几个例子的,结果发现光写了一个主键就写了一大堆了,然后时间也比较晚了,干脆就写到这吧,原本计划的几个其他例子后面再单独写吧

4.9K31

MySQL主键为什么不连续

(`id`), UNIQUE KEY `c` (`c`) ) ENGINE=InnoDB; 主键好处?...主键可以让主键索引尽量的保持递增顺序插入,避免页分裂,索引更加紧凑。 主键保存在何处?...不同的引擎对于增值的保存策略不同: MyISAM引擎的增值保存在数据文件中 InnoDB引擎的增值保存在内存里,但是在MySQL8.0以后,该自增值才可以被持久化:MySQL5.7以前,增值没有持久化每次重启后第一次打开表的时候...,会找增值的最大值max(id),然后将最大值加1作为这个表的增值;MySQL8.0版本会将自增值的变更记录在redo log中,重启时依靠redo log恢复。...1 继续执行插入数据操作,但是由于c=1的记录已经存在,所以会返回Duplicat key error,语句返回 上述执行过程可以看出,增值的修改是在真正插入数据的操作之前,如果数据真正插入的时候异常

8.3K20

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

MySQL replace into导致的id问题

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

6.9K20

mysql已存在的表增加字段

需求: 已有的mysql数据表,希望增加一个的字段,并设置新数据的初始值。 实际上不复杂,只是做个备忘。...InnoDB DEFAULT CHARSET=utf8; 测试数据: INSERT INTO `t_abc` (`name`) VALUES ('mike'), ('tom'), ('jack'); 添加字段并设置...新数据的起始值 /*增加一个主键字段,分两步操作*/ /*首先增加字段*/ alter table t_abc add column id int auto_increment primary...key; /*执行完上面这一条,字段增加,但值为空*/ /*执行这一条,它会自动为已存在的数据的字段赋初值,从1开始,同时将后续新增的数据从100开始*/ alter table t_abc auto_increment...; /*这里没有指定任何数值,执行完后只为字段赋从1开始的初始值,其实隐含的设置当前表字段从1开始*/ alter table t_abc auto_increment; /*将所有数据增加

10.7K10

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

当我们使用 MySQL 进行数据存储时,一般会为一张表设置一个主键,当有数据行插入时,该主键字段则会根据步长与偏移量增长(默认每次+1)。...的值并不是保存在表结构信息内的,对于不同的版本它们有如下的区别: 1.1.1 MySQL 8.0版本之前(重启后可能会产生变化): 计数器的值存储在内存中的,重启后丢弃,下一次将读取最大的一个ID...且当 Binlog 模式为 statement(SBR)时 ID 不能保证数据的正确性 1.5 ID 一定就是连续吗?...不一定,业务也不应该过分依赖 MySQL ID 的连续性,在以下三种情况下,并不能保证 ID 的连续性: 1.5.1 插入时的其他唯一索引冲突 假设已存在数据{1,张三},且张三所属的字段设置了唯一主键...当我们为表设置了主键后, ID 的范围则与主键的数据类型长度相关。

3K10
领券