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

mysql 主键语句_MySQL 主键

主键有两个性质需要考虑: 单调性 每次插入一条数据,其 ID 都是比上一条插入的数据的 ID 大,就算上一条数据被删除。...主键的单调性 为何会有单调性的问题? 这主要跟主键最大值的获取方式,以及存放位置有关系。 如果最大值是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删除而减小。...主键最大值怎么取的?存放到哪里?...从 MySQL 8.0 开始,主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...其他 如果主动指定 ID 为 0 或者 NULL 插入,则会使用数据库生成的 ID。

10.8K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql主键策略_MySQL 主键机制

    主键:特指在增列上定义的主键。 主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 增值保存在哪? 不同的存储引擎保存增值的策略不一样; a....锁的优化 a. 锁不是事务锁,在每次申请完就释放;在5.0版本会在语句执行完才释放,后续版本无须在语句执行完才释放;支持批量申请; b....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请 id 的策略(注:该策略是导致 id 不连续的第三种原因...:语句执行过程中,第一次申请 id,会分配 1 个;1 个用完以后,这个语句第二次申请 id,会分配 2 个;2 个用完以后,还是这个语句,第三次申请 id,会分配 4 个;依此类推,同一个语句去申请...id,每次申请到的 id 个数都是上一次的两倍。

    9.4K50

    浅谈MySQL

    原文:cnblogs.com/billyxp/archive/2013/01/22/2871737.html 一、增配置 通过如下建表语句就可以完成的配置 CREATE TABLE `test_inc...如果存在字段,MySQL会维护一个锁,和锁相关的一个参数为(5.1.22版本之后加入) innodb_autoinc_lock_mode:可以设定3个值,0,1,2 0:traditonal...六、的过程 第一种,插入空值的时候 当innodb_autoinc_lock_mode=0时 1、申请AUTO_INC锁 2、得到当前的AUTO_INCREMENT值n,并加1 3、执行插入操作...第二种,插入已经有值的 1、插入第一条数据 2、如果失败流程结束 3、如果成功,申请AUTO_INC锁 4、调用set_max函数,修改AUTO_INCREMENT 5、语句结束,释放AUTO_INC...为了保证主库和从库的ID的一致性,binlog中会有set insert_ID命令,标明这个load语句的第一行的ID值,这样在表锁的情况下,就可以保证一致性了。

    5K30

    MySQL锁的探究

    2.5 锁MySQL的锁是指在使用主键(Auto Increment)时,为了保证唯一性和正确性,系统会对字段进行加锁。这样可以确保同时插入多条记录时,每条记录都能够获得唯一的增值。...锁确保了插入记录的唯一性和正确性,避免了并发插入产生冲突。但同时也会带来一些性能上的影响,因为并发插入操作需要等待锁的释放。因此,在高并发的场景下,可能需要考虑使用其他方案来避免锁成为瓶颈。...Tips:锁跟事务无关,即使多个insert语句存在同一个事务中,每次insert都会申请最新的锁来获取最新的AUTO_INCREMENT值;获取到增值后释放,而不是事务结束释放;2)锁表锁需要注意的是...,锁是基于表级别的,而不是行级别的。...,触发表级别锁【Simple Inserts】 【Bulk Inserts】3)interleaved(交叉模式)在交叉模式下,所有的insert语句都不会使用锁(悲观锁),而是采用一个轻量级的

    10221

    深入剖析 MySQL

    之前的文章把 InnoDB 中的所有的锁都介绍了一下,包括意向锁、记录锁...锁巴拉巴拉的。但是后面我自己回过头去看的时候发现,对锁的介绍居然才短短的一段。...其实锁(AUTO-INC Locks)这块还是有很多值得讨论的细节,例如在并发的场景下,InnoDB 是如何保证该值正确的进行的,本章就专门来简单讨论一下 InnoDB 中的锁。...什么是锁 之前我们提到过,锁是一种比较特殊的表级锁。...行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...如果你对锁有足够的了解,那么这个问题将会迎刃而解。

    3.3K40

    Hive如何实现序列

    在利用数据仓库进行数据处理时,通常有这样一个业务场景,为一个Hive表新增一列字段(比如事实表和维度表之间的"代理主键")。...虽然Hive不像RDBMS如mysql一样本身提供主键的功能,但它本身可以通过函数来实现序列功能:利用row_number()窗口函数或者使用UDFRowSequence。...示例:table_src是我们经过业务需求处理的到的中间表数据,现在我们需要为table_src新增一列序列字段auto_increment_id,并将最终数据保存到table_dest中。...但是,需要注意二者的区别: row_number函数是对整个数据集做处理,序列在当次排序中是连续的唯一的。...可以考虑将UDFRowSequence扩展到一个第三方存储系统中,进行序号逻辑管理,来最终实现全局的连续唯一序号。

    4.8K40
    领券