移动云海山数据库(He3DB)MySQL关键类之Lex

2023年 12月 28日 109.1k 0

1注释说明

THD的父类字段Statement::lex保存解析出来的语法树信息 struct LEX继承于Query_table_list

2关键成员

SELECT_LEX_UNIT *unit: 语法树的顶层节点

SELECT_LEX *select_lex:顶层的第一个query语句块 unit->fitst->select()

SELECT_LEX *all_selects_list:通过链表连接query的语句块

TABLE_LIST *query_tables: 维护所有tables的一个全局链表(双向:pre、next)

应用:指针指向query table链表的最后

TABLE_LIST **query_tables_last: 指向前序链表中next_global数据的最后一个元素

应用:在query table 链表的最后加上元素

3 select语法树

3.1 SELECT_LEX_UNIT (st_select_lex_unit) This class represents a query expression (one query block or several query blocks combined with UNION

3.2 SELECT_LEX (st_select_lex)


具体的定义:这个类表示一个查询语句块,也就是查询规范,它是一个由SELECT关键字、表列表、WHERE子句、GROUP by等组成的查询。

table_list:FROM子句中的表(table)列表(list)-使用TABLE_List::next_local进行遍历

join:在优化器执行之后它指向相应的JOIN。只有在采用THD::LOCK_query_plan mutex时,才应更改此成员。

where:跟了where语句后的条件表示树 having:having条件

item_list: columns 和expressions的链表

其他的一些对应query语句的关键字 group by子语句、select和offset的限制等

3.3 整体描述

(391行,详细的介绍) 类st_select_lex_unit表示一个查询表达式。 类st_select_lex表示一个查询块。 查询表达式包含一个或多个查询块(多个表示我们有一个UNION查询)。

执行案例:联表子查询

unit是整个表达式 fake:Helper query block for query expression with UNION or multi-level ORDER BY/LIMIT select是一个个查询块,通过链表连接all_select_list连接连接 第一个select查询块是unit的salve、unit是select的master节点


整个语法树由SELECT_LEX_UNIT作为顶层,下面有多个select block。 THD::lex->unit指向顶层L1,THD::lex->select_lex指向顶层的select1

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论