MySQL中如何进行nest loop且不考虑hash join
发表于:2024-11-16 作者:千家信息网编辑
千家信息网最后更新 2024年11月16日,这期内容当中小编将会给大家带来有关MySQL中如何进行nest loop且不考虑hash join,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。只考虑nest lo
千家信息网最后更新 2024年11月16日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安全错误
数据库的锁怎样保障安全
润和软件开发有限公司招聘
数据库设计要
数据库技术查询
网络安全不断夯实
中华网络安全法施行时间
三门峡卫蚕网络技术有限公司
怎么通过映射连接服务器
软件开发综合实训开发
杭州湖畔科技网络技术
维护服务器安全吗
数据库和网站怎么交互
网络技术员 招聘
如何查找网站数据库
数据库中基本锁的类型
魔兽世界2015服务器
美国数据库产业的发展
亳州一中网络技术培训
网站大型服务器一般多少钱
软件开发怎么简称
如何保证数据库加密数据安全
服务器的开关一会明一会暗
延庆区网络技术售后服务
虎牙贱圣服务器管理员
手机一直连不上中信证券的服务器
嘉定区网络营销软件开发服务价格
数据库的访问权限在哪里设置
网络位置 媒体服务器
在哪找网络安全工程师
连接到公司服务器能干什么
北京市小型软件开发公司现状