java面试一日一题:mysql中的自增主键
问题:请讲下mysql中的自增主键
分析:该问题主要考察对mysql中自增主键的掌握,使用场景及如何设置
回答要点:
主要从以下几点去考虑
1、什么自增主键
2、使用场景是什么;
3、innodb_autoinc_lock_mode的设置;
从学习mysql开始,我们就知道在建表时经常建的是自增主键,并且在mysql的优化中经常看到的一句就是,最好有自增主键,那么自增主键是做什么用的。
自增主键的用法,
CREATE TABLE t1 (
c1 INT(11) NOT NULL AUTO_INCREMENT,
c2 VARCHAR(10) DEFAULT NULL,
PRIMARY KEY (c1)
) ENGINE=InnoDB;
上面的建表语句中c1就是一个自增主键。自增主键的好处是在进行数据插入时,会按照主键的顺序自增插入,且在innodb引擎下,会有一个聚集索引,该索引便是按照自增主键来组织的,也就是非叶子节点中存储的是自增主键。还会经常听到这样一句话,如果表中没有自增主键,那么变会选择一个不为空的唯一列作为主键索引来组织索引树,如果表中没有这样的列变会隐式生成一列rowid作为主键来组织索引树,当然此时的索引也是聚集索引。所谓聚集索引就是索引和数据是在一起的,像myIsam引擎则是非聚集索引,只有innodb的主键索引才是聚集索引,其叶子节点存储的是整行数据。
上面了解了自增索引的用法,下面讲下自增索引的使用场景。在分布式的系统中经常会有使用分布式ID的情况,有一种方案便是利用innodb引擎的自增索引,建一张表,表中有一个自增的主键列,该列的值可以作为分布式ID使用。
使用这样的方式会不会产生问题,会不会存在多个事务间的问题,要解决这个问题,首先要了解自增ID的生产原理。详见可以参看下面的官方文档,
https://dev.mysql.com/doc/refman/5.7/en/innodb-auto-increment-handling.html
从上面的官方文档中,可以大致得出这样的结论,自增主键的生成方式可以简单理解为事务在执行的时候会使用表锁锁住表,其他事务要想进行操作必须等待上一个事务释放表锁以后。随着mysql版本的升级,可以对该方式进行配置,于是有了innodb_autoinc_lock_mode属性,该属性可以对在插入自增主键时采用什么样的方式,其值有0 1 2三个值。
0 传统锁定模式
innodb_autoinc_lock_mode=0的情况,该值是为了兼容innodb_autoinc_lock_mode配置项未出现前的情况,在插入自增主键的时候使用的就是一把表锁。通过特殊的表级AUTO-INC锁进行锁定,可以确保为给定的INSERT 语句序列以可预测和可重复的顺序分配自动递增值,并确保自动递增值任何给定语句分配的都是连续的。
引入1和2的目的是为了增大并发,减少使用表级锁,提升性能,优化针对批量插入的场景
1 简单锁定模式
innodb_autoinc_lock_mode=1的情况,主要优化了批量插入和简单插入的场景下的AUTO-INC锁,该模式下可以保证任何给定语句分配的自动递增编号都是连续的。
2 混合锁定模式
inndob_autoinc_lock_mode=2的情况,这是最快、最具有扩展性的方案,但多个语句同时生成数字,生产的自增数字可能不是连续的。
innodb_autoinc_lock_mode的三种值都可以保证生成的数字是唯一递增的,但不能全部保证是连续的,且在主从复制的情况下也会有不安全的问题,因为主从复制的是binlog,而binlog的形式有3种。
有不当之处,请留言
java面试一日一题:mysql中的自增主键的更多相关文章
- MySQL 中的自增主键
MySQL 的主键可以是自增的,那么如果在断电重启后新增的值还会延续断电前的自增值吗?自增值默认为1,那么可不可以改变呢?下面就说一下 MySQL 的自增值. 特点 保存策略 1.如果存储引擎是 My ...
- java面试一日一题:mysql中常用的存储引擎有哪些?
问题:请讲下mysql中常用的引擎有哪些? 分析:该问题主要考察对mysql存储引擎的理解,及区别是什么? 回答要点: 主要从以下几点去考虑, 1.mysql的存储引擎的基本概念? 2.mysql中常 ...
- java面试一日一题:讲下mysql中的undolog
问题:请讲下mysql中undo log的作用 分析:mysql中有很多日志,例,bin log undo log redo log,要弄清楚这些日志的作用,就要了解这些日志出现的背景及要解决的问题: ...
- java面试一日一题:java中垃圾回收算法有哪些
问题:请讲下在java中有哪些垃圾回收算法 分析:该问题主要考察对java中垃圾回收的算法以及使用场景 回答要点: 主要从以下几点去考虑, 1.GC回收算法有哪些 2.每种算法的使用场景 3.基于垃圾 ...
- java面试一日一题:java中的垃圾回收器
问题:请讲下java中垃圾回收器有哪些? 分析:该问题主要考察hotspot虚拟机下实现的垃圾回收器 回答要点: 主要从以下几点去考虑, 1.垃圾回收器的种类 2.每种垃圾回收器的着重点是什么 前边的 ...
- java面试一日一题:讲下在什么情况下会发生类加载
问题:请讲下在什么情况下会发生类加载? 分析:该问题主要考察对java中类加载的知识,什么是类加载,为什么会发生类加载,什么情况下发生类加载? 回答要点: 主要从以下几点去考虑 1.什么是类加载: 2 ...
- MySQL 插入与自增主键值相等的字段 与 高并发下保证数据准确的实验
场景描述: 表t2 中 有 自增主键 id 和 字段v 当插入记录的时候 要求 v与id 的值相等(按理来说这样的字段是需要拆表的,但是业务场景是 只有某些行相等 ) 在网上搜的一种办法是 先获取 ...
- 面试|简单描述MySQL中,索引,主键,唯一索引,联合索引 的区别,对数据库的性能有什么影响(从读写两方面)
索引是一种特殊的文件(InnoDB 数据表上的索引是表空间的一个组成部分),它们 包含着对数据表里所有记录的引用指针. 普通索引(由关键字 KEY 或 INDEX 定义的索引)的唯一任务是加快对数据的 ...
- 简单描述 MySQL 中,索引,主键,唯一索引,联合索引 的区别,对数据库的性能有什么影响(从读写两方面) ?
索引是一种特殊的文件(InnoDB 数据表上的索引是表空间的一个组成部分),它们 包含着对数据表里所有记录的引用指针. 普通索引(由关键字 KEY 或 INDEX 定义的索引)的唯一任务是加快对数据的 ...
随机推荐
- 微信小程序:Navigator导航组件
导航组件:类似超链接标签. url:要跳转的页面路径,可以放绝对路径,也可以放相对路径,绝对路径指从pages作为根目录开始找到你要的页面. 找到你要找的页面的相对地址的方法:在vscode中,该页面 ...
- 鸿蒙开源第三方组件 ——B站开源弹幕库引擎的迁移(上)
鸿蒙入门指南,小白速来!0基础学习路线分享,高效学习方法,重点答疑解惑--->[课程入口] 目录: 一.弹幕库的基础知识 二.弹幕库的使用方法 三.sample解析 四.作者系列文章合集 前言 ...
- oracle 查看 FK constraint referenced_table及columns
select uc.table_name, uc.r_constraint_name, ucc.table_name, listagg(ucc.column_name, ',') within gro ...
- docker轻量级监控-sysdig
sysdig Sysdig = system(系统)+dig(挖掘).Sysdig 是一个开源系统发掘工具,用于系统级别的勘察和排障,可以把它看作一系列Linux系统工具的组合,主要包括: strac ...
- macOS下Chrome和Safari导入证实抓包HTTPS
目录 下载证书 mac OS导入证书 Chrome设置代理 Safari设置代理 下面的操作基于Mac OS Catalina(v10.15.3),抓包拦截工具基于Burp Suite v2.1.05 ...
- CCF(地铁修建):向前星+dijikstra+求a到b所有路径中最长边中的最小值
地铁修建 201703-4 这题就是最短路的一种变形,不是求两点之间的最短路,而是求所有路径中的最长边的最小值. 这里还是使用d数组,但是定义不同了,这里的d[i]就是表示从起点到i的路径中最长边中的 ...
- 2020年12月-第02阶段-前端基础-CSS Day03
CSS Day03 盒子模型(CSS重点) css学习三大重点: css 盒子模型 . 浮动 . 定位 主题思路: 理解: 1.能说出盒子模型有那四部分组成 2.能说出内边距的作用以及对盒子的影响 3 ...
- 一. MySQL基础语法
1. 案例库表 2. DQL语言(数据查询) 2.1 基础查询 -- 进入指定的库 USE myemployees; DESC employees; -- 使用SELECT查询字段 # 1.查询表中的 ...
- FreeBSD 乃至开源界中的孔乙己 再论苦难哲学之一
在许多狂热的FreeBSD 粉丝里,他们甚至不允许别人把FreeBSD写作freebsd,要和你强调,F和BSD都是大写的.还说这是什么尊重之类的东西.大抵和孔乙己的茴香豆的茴的有四种写法一样吧:&q ...
- JAVA常用的集合转换
在Java应用中进行集合对象间的转换是非常常见的事情,有时候在处理某些任务时选择一种好的数据结构往往会起到事半功倍的作用,因此熟悉每种数据结构并知道其特点对于程序员来说是非常重要的,而只知道这些是不够 ...