从Join的实现窥探MySQL迭代器

以如下left join查询语句为范例:

select*from t1 left join t2 on t1.c=t2.a;

以下初始化数据:

1DROPTABLE IF EXISTS `t1`;
2CREATETABLE `t1` (
3 `a` int DEFAULT NULL,
4 `b` varchar(20) DEFAULT NULL
5)
6INSERTINTO `t1` VALUES(1,'a');
7INSERTINTO `t1` VALUES(1,'b');
8INSERTINTO `t1` VALUES(4,'a');
9INSERTINTO `t1` VALUES(5,'a');
10
11DROPTABLE IF EXISTS `t2`;
12CREATETABLE `t2` (
13 `c` int DEFAULT NULL,
14 `d` varchar(20) DEFAULT NULL
15)
16INSERTINTO `t2` VALUES(9,'i');
17INSERTINTO `t2` VALUES(1,'i');
18INSERTINTO `t2` VALUES(2,'i');
19INSERTINTO `t2` VALUES(3,'i');

1.处理join的yacc入口

在sys_yacc.yy​文件内解析t1 left join t2 on t1.c=t2.a;对应处理位置。

1  table_reference outer_join_type table_reference ON_SYM expr
2{
3 $$= NEW_PTN PT_joined_table_on($1, @2, $2, $3, $5);
4}

其中outer_join_type对应。

1  outer_join_type:
2 LEFT opt_outer JOIN_SYM { $$= JTT_LEFT;}
3| RIGHT opt_outer JOIN_SYM { $$= JTT_RIGHT;}

入参处理在函数T_joined_table_on内。

2.移步到函数PT_joined_table_on

从PT_joined_table_on​声明可知其继承PT_joined_table​函数,入参左右表赋值为PT_joined_table内定义的tr1和tr2。

函数PT_joined_table_on​将输入join的左右表加入context内,并调用add_join_on将on内的条件加入右表,记录后续数据过滤条件。

3.执行阶段函数do_command(thd)

具体对应执行函数int mysql_execute_command(THD *thd, bool first_level)​,语句解析以及相应参数保存完成后,进入函数int mysql_execute_command(THD *thd, bool first_level)​,此函数内根据前面解析到的命令类型switch (lex->sql_command)​调用对应的处理函数,如当前语句为例查询命令解析为lex->sql_command = SQLCOM_SELECT​则进入函数lex->m_sql_cmd->execute(thd)​;其对应为sql_select.cc​内函数bool Sql_cmd_dml::execute(THD *thd)。

4.优化器操作,生成access_paths

sql_select.cc​内函数bool Sql_cmd_dml::execute(THD *thd)​函数内主要操作为函数execute_inner​,在函数execute_inner内首先会对当前的执行优化操作。

调用查询表达式Query_expression​的优化器unit->optimize​,此函数中会对该Query_expression​的内的每个查询块query_block分别先进行优化操作。

查询块内函数bool JOIN::optimize()​内会将每个查询块优化生成查询执行计划 ,具体执行函数为函数JOIN::create_access_paths()内create_root_access_path_for_join()​函数,以当前查询为例在函数create_root_access_path_for_join​内根据参数条件主要调用ConnectJoins函数。

在函数ConnectJoins​内调用FindSubstructure判断是join类型内连接、外连接、半链接等类型。

根据FindSubstructure​返回join类型调用相应的函数生成path,当前查询为例执行调用CreateHashJoinAccessPath生成path。

至此查询块query_block​的优化操作和path生成完成,查询块优化操作完成后再执行整体表达式Query_expression的优化和path的生成,因为目前范例仅为一个查询块,所以当前无需再做整体表达式的优化和path生成。

5.创建迭代器iterator

根据上一步生成的path调用CreateIteratorFromAccessPath函数生成迭代器,用于循环操作各表数据。

在此函数内会根据path的类型调用生成不同类型的迭代器,以目前范例为例,会调用迭代器类型为HashJoinIterator。

6.上述4、5步执行完成后,执行迭代器iterator

在函数execute_inner​内执行完成上述4、5步骤操作后主要继续执行unit->execute(thd)​函数,其对应执行查询表达式函数bool Query_expression::ExecuteIteratorQuery(THD *thd)。

函数Query_expression::ExecuteIteratorQuery​内主要执行m_root_iterator->Init()​,迭代器iterator初始化,当前范例为使用HashJoinIterator​类型迭代器,因此对应执行迭代器函数HashJoinIterator::Init()。

执行m_build_input->Init()​来初始右表table句柄,用于下面函数BuildHashTable()​内读取右表数据以便初始化返回数据存储表hashtable​,值得注意的是BuildHashTable​函数内会根据处理流程调用SetReadingProbeRowState设置执行状态用于引导后续迭代器iterator执行流程。

函数内最后调用InitProbeIterator​执行m_probe_input->Init()初始左表table句柄用于下面函数读取左表数据。

上面操作完成后执行m_root_iterator->Read()​函数,以当前查询为范例其对应int HashJoinIterator::Read()​函数,执行过程中根据前面SetReadingProbeRowState​设置的流程状态再选择对应的操作函数,以当前范例则会循环读取左表数据,而在操作函数内也会调用SetReadingProbeRowState​来设置迭代器iterator下一步操作,直至迭代器处理完成,其中在函数Query_expression::ExecuteIteratorQuery,每次读取一条成功后就会调用send_data操作将结果发送至客户端,直至所有查询结果发送完成。

7.至此客户端收到相应显示查询结果。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/237383.html<

(0)
运维的头像运维
上一篇2025-04-22 11:05
下一篇 2025-04-22 11:06

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注