MySQL索引自优化算法

263次阅读
没有评论

共计 1445 个字符,预计需要花费 4 分钟才能阅读完成。

InnoDB 架构图:

MySQL 索引自优化算法

查看优化器算法开关:select @@optimizer_switch;

修改,例如:set global optimizer_switch='batched_key_access=on';,退出客户端,重新进入客户端查看修改结果。

设置方法也可以使用优化器提示 Hints 的形式,或者设置 my.cnf 配置文件。

索引自优化

AHI

Adaptive Hash Index,即自适应哈希索引,作用是自动评估热内存索引 page,生成 Hash 索引表,帮助 InnoDB 快速读取索引页,加快索引读取的速度,相当于索引的索引。

Change Buffer

比如 insert、update、delete 数据,对于聚簇索引会立即更新,而对于辅助索引不是实时更新的。

在 InnoDB 内存结构中,加入了 Insert Buffer,现在版本叫 Change Buffer。Change Buffer 功能是临时缓冲辅助索引需要的数据更新。当我们需要査询新 insert 的数据,会在内存中进行 merge 合并操作,此时辅助索引就是最新的。

优化器算法

ICP

Index Condition Pushdown,即索引下推,作用是解决联合索引只能部分应用的情况。为了减少没必要的数据页被扫描,将不走索引的条件,在 engine 层取数据之前先做二次过滤,一些无关数据就会被提前过滤掉。

例如,有一个索引 index(a,b,c),查询语句:select * from t where a= and c=,在 server 层先做 a 列过滤条件的索引优化,在将 c 列的过滤下推到 engine 层先做过滤,再加载数据页。

MRR

Multi-Range Read,是优化器将随机磁盘 IO 转化为顺序磁盘 IO 以降低查询过程中 IO 开销的一种手段,是一种回表优化。

回表是指先走二级索引,找到对应的主键值,再根据主键值再到聚集索引当中,拿到一行行的数据。由于二级索引上引用的主键值不一定是有序的,因此有可能造成大量的随机 IO,如果回表前把主键值给排下序,那么在回表时就可以用顺序 IO 取代原本的随机 IO。

具体可参考:https://mariadb.com/kb/en/multi-range-read-optimization/

SNLJ

Index Nested-Loop Join,INLJ 算法,即嵌套循环连接,常用于连接小表或是一个表中数据量不大的子集。具体实现方式是先遍历外表,对于每一行,再遍历内表,找到符合连接条件的行,返回结果。

Simple Nested-Loop Join,即 SNLJ 算法。具体实现方式是驱动表全表扫描取出所有字段,逐行匹配被驱动表,而被驱动表未使用到索引,每次匹配页都进行一次全表扫描。

BNL

Block Nested-Loop Join,即块嵌套循环连接。该算法使用了 join buffer 作为优化,其中由参数 join_buffer_size 设定 join_buffer 大小,默认值是 256K。

在 A 表和 B 表关联条件匹配时,不再一次一次进行循环,而是采用一次性将驱动表的关联值和非驱动表匹配. 一次性返回结果。BNLJ 算法主要优化了 CPU 消耗,减少了 IO 次数。

BKA

Batched Key Access,主要是用来优化非驱动表关联列有辅助索引,相当于 BNL+MRR 的功能。要启动 KBA 算法优化,先设置:set global optimizer_switch='mrr=on,mrr_cost_based=off,batched_key_access=on';,退出客户端,重新进入客户端查看修改结果。

正文完
 0
阿伯手记
版权声明:本站原创文章,由 阿伯手记 于2024-02-22发表,共计1445字。
转载说明:本站原创内容,除特殊说明外,均基于 CC BY-NC-SA 4.0 协议发布,转载须注明出处与链接。
评论(没有评论)
验证码

阿伯手记

阿伯手记
阿伯手记
喜欢编程,头发渐稀;成长路上,宝藏满地
文章数
766
评论数
204
阅读量
447500
今日一言
-「
热门文章
职场救急!AI请假话术生成器:1秒定制高通过率理由

职场救急!AI请假话术生成器:1秒定制高通过率理由

超级借口 不好开口?借口交给我!智能生成工作请假、上学请假、饭局爽约、约会拒绝、邀约推辞、万能借口等各种借口理...
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
巴别英语:用美剧和TED演讲轻松提升英语听力与口语

巴别英语:用美剧和TED演讲轻松提升英语听力与口语

还在为枯燥的英语学习而烦恼吗?巴别英语通过创新的美剧学习模式,让英语学习变得生动有趣。平台提供海量美剧和 TE...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
TVAPP:开源电视盒子资源库,一键打造家庭影院

TVAPP:开源电视盒子资源库,一键打造家庭影院

导语 TVAPP 是一个专为 Android TV 电视盒子用户打造的开源影音资源库,集成了影视、直播、游戏等...
2025年12月 每日精选

2025年12月 每日精选

关于每日精选栏目 发现一些不错的资源,点击 这里 快速投稿。 12 月 26 日 .ax 顶级域 目前全球唯一...
最新评论
15220202929 15220202929 怎么用
八对 八对 麻烦大佬更新下【堆新】的友链站名:八对星星描述:极目星视穹苍无界•足履行者大地有疆链接:https://8dui.com图标:https://cf.8dui.com/logo.webp横标:https://cf.8dui.com/logo-w.webp订阅:https://8dui.com/rss.xml
三毛笔记 三毛笔记 已添加
DUINEW DUINEW 已添加贵站,期待贵站友链~博客名称:堆新博客地址:https://duinew.com/博客描述:堆新堆新,引力向新!——堆新(DUINEW)博客头像:https://d.duinew.com/logo.webp横版头像:https://d.duinew.com/logo-w.webp博客订阅:https://duinew.com/rss.xml
hedp hedp 没看懂
bingo bingo 直接生成就可以啦,也可以添加一些选项
满心 满心 申请更新下友联信息,原名:满心记,现名:周天记原域名:qq.mba,现域名:zhoutian.com描述:我在人间混日子
开业吉日 开业吉日 没看明白这个怎么用
开业吉日 开业吉日 beddystories 这个网站太赞了,收藏
热评文章
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
清华大学官方免费DeepSeek教程

清华大学官方免费DeepSeek教程

AI 领域近期最引人注目的焦点当属 DeepSeek,这款由中国创新企业深度求索研发的人工智能工具,正以开放源...
Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 是一款基于 Fastify、Vercel 和 Supabase 构建的 URL 缩短服务...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 是一个致力于为儿童提供优质睡前故事的在线平台,用户可以在这里找到来自世界各地的经典故...
DrawLink:一键生成链接视觉卡片,提升分享点击率

DrawLink:一键生成链接视觉卡片,提升分享点击率

小贴士 :此站或已变迁,但探索不止步。我们已为您备好「类似网站」精选合集,相信其中的发现同样能为您带来惊喜。