MySQL中如何进行nest loop且不考虑hash join
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,这期内容当中小编将会给大家带来有关MySQL中如何进行nest loop且不考虑hash join,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。只考虑nest lo
千家信息网最后更新 2025年01月22日MySQL中如何进行nest loop且不考虑hash join
这期内容当中小编将会给大家带来有关MySQL中如何进行nest loop且不考虑hash join,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
只考虑nest loop,不考虑hash join
条件如下:
a,b,c where a.id=b.id and a.id=c.id where a.name='gaopeng',b.name='gaopeng',c.name='gaopeng'
假设a为驱动表,先连接b,再连接c ,且b,c表 id均有索引。
流程如下:
loop:1、访问驱动表a,过滤条件a.name='gaopeng',这个过程有索引用索引 获得第一条数据记做row_a1,这里可能会匹配出多行数据,需要循环 loop: 2、访问被驱动表b,连接条件a.id=b.id 相当于条件b.id = row_a1.id 这个过程b.id 有索引用索引,得到连接后的数据 a.\*+b.\*,这里可能 会匹配出多行数据,需要循环 3、每行数据,施加过滤条件b.name='gaopeng',假设 得到第一条数据记做row_b1 loop: 4、访问被驱动表c,连接条件a.id=c.id 相当于条件c.id = row_b1.id 这个过程c.id 有索引用索引,得到连接后的数据 a.\*+b.\*+c.\*,这里可能 会匹配出多行数据,需要循环 5、每行数据,施加过滤条件c.name='gaopeng',假设 得到第一条数据记做row_c1
这里row_c1就是最终的第一条数据。其实就是3层嵌套循环的意思。
后面使用debug进行验证。。
被驱动表全表扫描会使用A Block Nested-Loop (BNL) 代替A simple nested-loop join (NLJ) ,使用join buffer , 第1步 会一次读取多行数据 假设读取了row_an行 ,第2步 条件相当于 b.id in (row_a1.id,row_a2.id…row_an.id)这样只会一次全表扫描了。。不然每条全表扫描更慢,及使用
上述就是小编为大家分享的MySQL中如何进行nest loop且不考虑hash join了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。
数据
条件
驱动
索引
多行
循环
就是
过程
内容
分析
专业
中小
内容丰富
意思
文章
更多
流程
知识
篇文章
行业
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
2020北京网络安全大会
奉贤区品质数据库有哪些
软件开发上架产品
物联网客户端软件开发
vf创建数据库的步骤
禅道连接mysql的数据库配置
云服务器ecs的学习感受
计算机网络技术五年级
银行数据机房网络安全排查
文件存储的数据库
网络安全童谣歌曲
联想机架式服务器怎么打开机盖
眉山网络软件开发
我的世界狼族服务器
英汇网络技术
fgo哪个服务器人最多
福州荆玥软件开发有限公司
访问web数据库常见技术
计算机网络技术创新案例
软件开发都有哪些软件开发好
ftp服务器dir命令卡住
智能医生软件开发
上海腾科网络技术有限公司电话
南京衣谷互联网科技有限公司
网络安全等级保护测评考证
网络安全条款具体内容
上海信息网络安全协会
网络安全负责制
网络安全法信息用于其他用途
哪个数据库无法进行静脉用药