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

mysql主键策略_MySQL 主键机制

对于MyISAM引擎,增值保存在数据文件中; b. Innodb引擎,mysql5.7之前,增值保存在内存中,而且不会持久化增值。...增值修改策略? a. 在插入时如不指定或指定为0,null,则使用当前的增值填到字段;并设置当前增值=当前增值+auto_increment_increment 步长; b....增值修改发生在插入数据的操作之前,如果插入失败,增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少id锁带来的性能影响,mysql不会修改回去之前的增值; 4....一次性insert多条记录时,如果能计算出需要多少个id,就一次性申请,申请完就释放; c. insert … select 默认会使用语句级的锁,只有语句执行完才会释放锁,为了数据的一致性; d....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请 id 的策略(注:该策略是导致 id 不连续的第三种原因

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

    mysql id和UUID做主键性能分析,及最优方案

    1.为什么要使用uuid做主键 (1).其实在innodb存储引擎下,增长的id做主键性能已经达到了最佳。不论是存储和读取速度都是最快的,而且占的存储空间也是最小。...(2).但是在我们实际到项目中会碰到问题,历史数据表的主键id会与数据表的id重复,两张id做主键的表合并时,id一定会有冲突,但如果各自的id还关联了其他表,这就很不好操作。...为了存储和查询性能应该使用增长id做主键。...(2).对于InnoDB的主索引,数据会按照主键进行排序,由于UUID的无序性,InnoDB会产生巨大的IO压力,此时不适合使用UUID做物理主键,可以把它作为逻辑主键,物理主键依然使用ID。...4.如果非要使用uuid做主键,下面是小建议: 如果是主从即M-S模式,最好是不使用mysql自带函数uuid来生成唯一主键,因为主表生成的uuid要再关联从表时,需要再去数据库查出这个uuid,需要多进行一次数据库交互

    8.1K20

    线上MySQLid用尽怎么办?

    MySQLid都定义了初始值,然后不断加步长。虽然自然数没有上限,但定义了表示这个数的字节长度,计算机存储就有上限。...那id用完,会怎么样? 表定义增值id 表定义的增值达到上限后的逻辑是:再申请下一个id时,得到的值保持不变。...验证该结论:通过gdb修改系统的row_id。用gdb是为了便于复现问题,只能在测试环境使用。...所以应该在InnoDB表中主动创建主键:当表id到达上限后,再插入数据时会报主键冲突错误。 毕竟覆盖数据,就意味着数据丢失,影响数据可靠性;报主键冲突,插入失败,影响可用性。...因为MySQL使用了一个唯一数组 给新线程分配thread_id时的逻辑: 总结 每种id有各自的应用场景,在达到上限后的表现也不同: 表的id达到上限后,再申请时它的值就不会改变

    2.1K20

    线上MySQLid用尽怎么办?

    作者:废柴程序员 链接:https://www.jianshu.com/p/a6bc14005b52 MySQLid都定义了初始值,然后不断加步长。...那id用完,会怎么样? 图片 表定义增值id 表定义的增值达到上限后的逻辑是:再申请下一个id时,得到的值保持不变。...验证该结论:通过gdb修改系统的row_id。用gdb是为了便于复现问题,只能在测试环境使用。...所以应该在InnoDB表中主动创建主键:当表id到达上限后,再插入数据时会报主键冲突错误。 毕竟覆盖数据,就意味着数据丢失,影响数据可靠性;报主键冲突,插入失败,影响可用性。...因为MySQL使用了一个唯一数组 图片 给新线程分配thread_id时的逻辑: 图片 总结 每种id有各自的应用场景,在达到上限后的表现也不同: 表的id达到上限后,再申请时它的值就不会改变

    3.9K20

    mysql为什么建议使用主键

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

    5K31

    线上MySQLid用尽怎么办?

    MySQLid都定义了初始值,然后不断加步长。虽然自然数没有上限,但定义了表示这个数的字节长度,计算机存储就有上限。...那id用完,会怎么样? 表定义增值id 表定义的增值达到上限后的逻辑是:再申请下一个id时,得到的值保持不变。...验证该结论:通过gdb修改系统的row_id。用gdb是为了便于复现问题,只能在测试环境使用。...所以应该在InnoDB表中主动创建主键:当表id到达上限后,再插入数据时会报主键冲突错误。 毕竟覆盖数据,就意味着数据丢失,影响数据可靠性;报主键冲突,插入失败,影响可用性。...因为MySQL使用了一个唯一数组 给新线程分配thread_id时的逻辑: 总结 每种id有各自的应用场景,在达到上限后的表现也不同: 表的id达到上限后,再申请时它的值就不会改变,进而导致继续插入数据时报主键冲突错误

    3.2K10

    浅谈MySQL

    点击上方“Java后端技术栈“关注 持续推送技术干货 最近在工作中遇到很多使用MySQL自带的autoincrement函数作为发号器,在实际使用中当并发比较小的时候还没有问题,一旦并发增加就会出现很多问题...()函数可以获得最后一个插入的数字 select last_insert_id(); 五、锁 如果存在字段,MySQL会维护一个锁,和锁相关的一个参数为(5.1.22版本之后加入) innodb_autoinc_lock_mode...目前MySQL默认的配置为1。...为了保证主库和从库的ID的一致性,binlog中会有set insert_ID命令,标明这个load语句的第一行的ID值,这样在表锁的情况下,就可以保证一致性了。...锁分享就到这里了。

    5K30

    如果MySQL ID 用完了,怎么办?

    作者 | 方志朋 来源 | https://mp.weixin.qq.com/s/Yqo5PaTtQcQTn4p8BE6SGg 如果你用过或了解过MySQL,那你一定知道主键了。...既然有上限,就总有被用完的时候,如果id用完了,怎么办呢?今天就一起来学习下吧。...上面介绍了几种MySQL自身的一些id,其实,实际运用中,我们也可能会选择外部的主键,然后持久化到数据库,以此来代替数据库自身的id。下面来说说吧。...因为我自己在实际应用中使用发现它的很多优点。 redis自身是原子性的,因此高并发也是线程安全的。假设主键字段长度20,我们以时间+数来构成主键,例如:8位日期+12数。...5、 thread_id 是我们使用中最常见的,而且也是处理得最好的一个 id 逻辑了 6、 redis外部,毫秒级别,理论上会出现重复值,但是概率极小,可以忽略不计 7、 其实,每种id

    1.2K20

    深入剖析 MySQL

    怎么说呢,说他对,但是他也不完全对。 行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...在锁模式处于连续模式下时,如果 INSERT 语句能够提前确定插入的数据量,则可以不用获取自锁,举个例子,像 INSERT INTO 这种简单的、能提前确认数量的新增语句,就不会使用锁,这个很好理解...SELECT ,都不会使用 AUTO-INC 锁,而是使用较为轻量的 mutex 锁。这样一来,多条 INSERT 语句可以并发的执行,这也是三种锁模式中扩展性最好的一种。...鱼和熊掌 但是如果你的 MySQL 版本仍然默认使用连续模式,但同时又想要提高性能,该怎么办呢?这个其实得做一些取舍。...如果你可以断定你的系统后续不会使用 Binlog,那么你可以选择将自锁的锁模式从连续模式改为交叉模式,这样可以提高 MySQL 的并发。

    3K20

    深入剖析 MySQL

    怎么说呢,说他对,但是他也不完全对。 行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...在锁模式处于连续模式下时,如果 INSERT 语句能够提前确定插入的数据量,则可以不用获取自锁,举个例子,像 INSERT INTO 这种简单的、能提前确认数量的新增语句,就不会使用锁,这个很好理解...SELECT ,都不会使用 AUTO-INC 锁,而是使用较为轻量的 mutex 锁。这样一来,多条 INSERT 语句可以并发的执行,这也是三种锁模式中扩展性最好的一种。...鱼和熊掌 但是如果你的 MySQL 版本仍然默认使用连续模式,但同时又想要提高性能,该怎么办呢?这个其实得做一些取舍。...如果你可以断定你的系统后续不会使用 Binlog,那么你可以选择将自锁的锁模式从连续模式改为交叉模式,这样可以提高 MySQL 的并发。

    3.3K40

    MySQL锁的探究

    2.5 MySQL锁是指在使用主键(Auto Increment)时,为了保证唯一性和正确性,系统会对字段进行加锁。这样可以确保同时插入多条记录时,每条记录都能够获得唯一的增值。...1)插入原理MySQL锁的实现机制是使用了一个名为"auto-increment lock"的互斥锁。...当使用INSERT语句插入一条新记录时,MySQL会自动为字段加锁,防止其他并发的插入操作同时获取相同的增值。这个锁是在内部实现的,不需要用户手动创建或管理。...锁确保了插入记录的唯一性和正确性,避免了并发插入产生冲突。但同时也会带来一些性能上的影响,因为并发插入操作需要等待锁的释放。因此,在高并发的场景下,可能需要考虑使用其他方案来避免锁成为瓶颈。...,触发表级别锁【Simple Inserts】 【Bulk Inserts】3)interleaved(交叉模式)在交叉模式下,所有的insert语句都不会使用锁(悲观锁),而是采用一个轻量级的

    11921

    id用完怎么

    我们知道mysql中存在很多id,然后不断增长,由于只要给id定义了这个数的字节长度,那么他就有了上限,比如无符号整型(unsigned int)是4个字节,因此他的上限是2^32-1, 表定义增值...id 表定义的增值达到上限后的逻辑是,在申请下一个id时,得到的值保持不变....就会导致下一个insert语句拿到相同的id,试图执行的时候,就会报主键冲突错误,因此在建表的时候你需要你的表是否可能达到这个上限,如果有可能就应该创建8个字节的bigint unsigned InnoDB系统...,但是如果global_query_id达到上限之后,就会继续从0开始计算,理论上还是会出现同一个binlog有相同的xid,又因为global_querey_id定义为8个字节,的上限是2^64-...thread_id 线程id是我们最常见的一种id,我使用show processlist的第一列计数就是thread_id, thread_id的逻辑很好理解,系统保存一个全局变量thread_id_conuter

    1.1K20

    如果MySQL ID 用完了,该怎么办?

    如果你用过或了解过MySQL,那你一定知道主键了。每个id都是定义了初始值,然后按照指定步长增长(默认步长是1)。...既然有上限,就总有被用完的时候,如果id用完了,怎么办呢?今天就一起来学习下吧。...上面介绍了几种MySQL自身的一些id,其实,实际运用中,我们也可能会选择外部的主键,然后持久化到数据库,以此来代替数据库自身的id。下面来说说吧。...Redis主键 其实外部主键的生成方式有很多,为什么我要介绍redis呢?因为我自己在实际应用中使用发现它的很多优点。 redis自身是原子性的,因此高并发也是线程安全的。...5、 thread_id 是我们使用中最常见的,而且也是处理得最好的一个 id 逻辑了 6、 redis外部,毫秒级别,理论上会出现重复值,但是概率极小,可以忽略不计 7、 其实,每种id

    78920

    mysql面试题43:MySQL主键用完了怎么办?

    该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:MySQL主键用完了怎么办?...当MySQL中的主键用完了(达到了最大值),可以考虑以下几种解决方案: 1.扩大数据类型: 如果你的主键列的数据类型是整数,例如INT,你可以考虑将数据类型扩大为更大的整数类型,例如BIGINT...2.重新设计主键: 如果主键用完了,你可以考虑重新设计表的主键,使用其他类型的主键,例如UUID(通用唯一标识符)或字符串。这样的主键不会受限于整数的最大值,但可能会导致索引性能下降。...3.循环使用主键值: 如果你确定主键用完后不会再插入新的数据,你可以考虑从头开始使用主键值,即将主键值循环使用。这样可以继续使用原来的主键列,但要小心避免主键冲突。...4.分区表: 如果你使用了分区表,可以考虑创建新的分区来存储数据,从而继续使用主键。这将允许你将数据分散到多个分区中,延长主键的使用寿命。

    25900
    领券