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

mysql 主键语句_MySQL 主键

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

10.8K10

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
您找到你想要的搜索结果了吗?
是的
没有找到

深入剖析 MySQL

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

3.2K40

MySQL主键详解「建议收藏」

每次重启后,第一次打开表的时候,都会去找增值的最大值max(id),然后将max(id)+步长作为这个表当前的增值 select max(ai_col) from table_name for update...(初始值)开始,以auto_increment_increment(步长)为步长,持续叠加,直到找到第一个大于X的值,作为新的增值 三、增值的修改时机 创建一个表t,其中id是主键字段、c是唯一索引...id的值,获取表t当前的增值2 3.将传入的行的值改成(2,1,1) 4.将表的增值改成3 5.继续执行插入数据操作,由于已经存在c=1的记录,所以报Duplicate key error(唯一冲突...出现了主键不连续的情况 唯一冲突和事务回滚都会导致主键id不连续的情况 四、锁的优化 id锁并不是一个事务锁,而是每次申请完就马上释放,以便允许别的事务再申请 但在MySQL5.0版本的时候...0,表示采用之前MySQL5.0版本的策略,即语句执行结束后才释放锁 2.这个参数设置为1 普通insert语句,锁在申请之后就马上释放 类似insert … select这样的批量插入数据的语句,

5.8K40

Spring JDBC-和行集RowSet

概述 的使用 Oracle以序列方式产生主键值 MySQL以表方式产生主键值 如何规划主键方案 小结 以行集返回数据 示例 示例源码 概述 Spring JDBC提供了对及行集的支持...,对象让用户可以不依赖数据库的,在应用层为新纪录提供主键。...---- 的使用 一般数据库都提供了的功能,比如MySql的auto_increment , SQL Server的identifty字段等....观察ID,是按照定义的序列生成的ID ---- MySQL以表方式产生主键值 在MySQL数据库中创建一张用于维护artisan主键的artisan_id表 create table artisan_id...---- 小结 在高并发的系统中,如果采用基于序列表的方式创建主键值,则应该考虑两个层面的并发问题: 第一:应用层获取主键的并发问题,Spring的DataFielMaxValueIncrementer

54020

MySQL replace into导致的id问题

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

6.9K20

MySQL主键为什么不连续

主键可以让主键索引尽量的保持递增顺序插入,避免页分裂,索引更加紧凑。 主键保存在何处?...不同的引擎对于增值的保存策略不同: MyISAM引擎的增值保存在数据文件中 InnoDB引擎的增值保存在内存里,但是在MySQL8.0以后,该自增值才可以被持久化:MySQL5.7以前,增值没有持久化每次重启后第一次打开表的时候...,会找增值的最大值max(id),然后将最大值加1作为这个表的增值;MySQL8.0版本会将自增值的变更记录在redo log中,重启时依靠redo log恢复。...(默认值是1)开始,以auto_increment_increment(默认值是1)为步长,持续叠加,直到找到第一个大于X的值,作为新的增值 唯一冲突导致主键不连续 insert into t...t\G 可以看到主键已经从3变成4,但是并没有因为事务的回滚回退。

8.3K20

mysql为什么建议使用主键

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

4.9K31

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】什么是约束?如何使用约束条件?主键、、外、非空....

约束 ⑦【MySQL】约束条件 1. 约束的基本使用 2. 外约束 ⑦【MySQL】约束条件 1. 约束的基本使用 约束: 什么是约束? 约束是作用于表中字段上的规则,用于限制存储在表中的数据。...—— 用来让两证表的数据之间建立连接,保证数据的一致性和完整性 FOREIGN KEY ⑦约束 AUTO_INCREMENT -- 案例 /* 创建表 ID唯一标识:id、int、主键且 姓名...CHAR(1) COMMENT '状态' DEFAULT 1, gender CHAR(1) COMMENT '性别' ); -- 查看表结构 DESC test; -- 向表中插入数据,字段可以不指定...外约束 如何添加外约束?: 方式一(在创建表时指定外约束): CREATE TABLE 表名( 字段名 数据类型, ......,存在则将外关联的字段值设置为null(前提是外关联字段可以为null) SET DEFAULT:在父表进行更新/删除时,首先检查记录是否存在外,存在则将外关联的字段值设置为一个默认值(Innodb

349100
领券