| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 大数据 -> MySQL面试题 -> 正文阅读 |
|
[大数据]MySQL面试题 |
目录 Mysql索引用B+树有什么优势,除了B+树还有什么数据结构 请描述下一条查询sql的执行流程
Mysql索引用B+树有什么优势,除了B+树还有什么数据结构
B Tree在枝节点存储键值、数据地址、节点引用。 AVL Tree 左右子数深度差绝对值不能超过1. 索引创建应该注意哪些点
请例举你所知道的Mysql的锁!并做简单说明粒度纬度: 表锁、行锁、页锁 类型:共享锁、排他锁、意向共享锁、意向排他锁 用户:乐观锁、悲观锁 算法:记录锁、临建锁、间隙锁 1、共享锁(shard locks) 获取一行数据的读锁以后,阻塞其他事务修改,可以用在不允许修改数据的情况下。也叫做读锁 2、排它锁(Exclusive Locks) 用来操作数据的,也叫写锁。只要一个事务获取了一行数据的排它锁,其他事务就不能获取这一行的共享锁和排它锁。 加锁方式: 自动排他锁、For update 3、意向锁(Intention Locks) 在给数据加 共享锁之前,数据库会自动给这张表加上意向锁,表示我预约了。 当数据量多的时候提高加锁效率 4、记录锁(锁索引列) 记录锁是对索引记录的锁定。 例如,SELECT c1 FROM t WHERE c1 = 10 FOR UPDATE; 防止任何其他事务插入,更新或删除t.c1的值为10的 5、间隙锁(锁范围) gap锁定是锁定索引记录之间的gap,或锁定在第一个或最后一个索引记录之前的gap上。 6、临建锁 它是MySQL里面默认的行锁算法,相当于记录锁加上间隙锁。 左开右闭 为什么innoDB的RR能解决幻读问题通过mvcc+lbcc来解决的,mvcc解决快照读,lbcc解决当前读 1、LBCC(Lock Based Concurrency Control) 基于锁的并发控制 要保证前后两次读取的数据一致,那么我读取数据时,锁定操作的数据,不允许其他事务修改。 缺点:不支持并发的读写操作,影响效率 2、MVCC(Multi Version Concurrency Control) 多版本的并发控制 在修改数据之前给他建立一个备份或快照,后面事务读的时候去读取快照 MVCC原理概念: InnoDB为每行记录都添加了两个隐藏字段 DB_TRX_ID,6字节,事务id,数据在哪个事务插入或修改为新数据,就记录为当前事务id DB_ROLL_PTR,7字节,回滚指针(删除版本号,数据被删除或者记录为旧数据时,记录当前事务id,没修改和删除时为null)旧数据存储在undo log中 什么是覆盖索引,什么是索引下推,什么是回表覆盖索引 : 使用非主键索引,不管是单列索引还是联合索引,如果select的数据列只能从索引中取得,不必从数据区读取,这时候使用的索引就是覆盖索引,避免了回表。 索引下推:
回表: 非主键索引,我们会通过索引找到 主键索引的键值,在通过主键值查出索引里面没有的数据,它比基于主键索引的查询多了一颗索引树,这个过程就叫回表。 索引失效的场景1、联合索引 中where条件必须放第一个索引,最左原则,否则索引失效 2、使用OR关键字的前后条件必须都有索引,否则索引失效 3、like 使用了%xx,前匹配是全文搜索,索引失效,可以改为全文索引 4、索引上使用了函数计算(+-*/,avg count ) 5、字符串索引 没有添加引号,导致隐式转换 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/23 20:28:34- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |