基于SqlNode的血缘解析
创始人
2024-02-19 11:19:52
0

案例分析

基于社区当前最新版本calcite-1.32.0进行分析

当前的SqlValidatorTest$testFieldOrigin中有一个单测可以直接用来调试
在这里插入图片描述

调试后,很快就能在测试专用方法assertFieldOrigin找到SqlValidatorTest$getFieldOrigins这个血缘入口方法

public SqlValidatorFixture assertFieldOrigin(Matcher matcher) {tester.validateAndThen(factory, toSql(false), (sap, validator, n) -> {final List> list = validator.getFieldOrigins(n);final StringBuilder buf = new StringBuilder("{");int i = 0;for (List strings : list) {if (i++ > 0) {buf.append(", ");}if (strings == null) {buf.append("null");} else {int j = 0;for (String s : strings) {if (j++ > 0) {buf.append('.');}buf.append(s);}}}buf.append("}");assertThat(buf.toString(), matcher);});return this;
}

getFieldOrigins具体实现如下

@Override public List<@Nullable List> getFieldOrigins(SqlNode sqlQuery) {if (sqlQuery instanceof SqlExplain) {return Collections.emptyList();}// validate获得query的rowType,final RelDataType rowType = getValidatedNodeType(sqlQuery);final int fieldCount = rowType.getFieldCount();if (!sqlQuery.isA(SqlKind.QUERY)) {return Collections.nCopies(fieldCount, null);}// 再遍历rowType获得每个filed的origin列final List<@Nullable List> list = new ArrayList<>();for (int i = 0; i < fieldCount; i++) {list.add(getFieldOrigin(sqlQuery, i));}return ImmutableNullableList.copyOf(list);
}

getFieldOrigin是处理每个Field的方法,但是看代码只支持select语句,不支持insert语句

注意这里的selectItem是擦除了别名的,上面代码有个stripAs方法;同时也只处理了别名,而没有处理其他情况

在这里插入图片描述
具体的实现如下:通过sqlSelect获得scope,每个scope再取出对应selectItem的SqlQualified

注意namespace可以获得table path

selectItem$1selectItem$2selectItem$nsqlSelectSelectScopeSqlQualified$1SqlQualified$2SqlQualified$n

SqlQualified封装了namespace+identifier(table+column)
在这里插入图片描述
至此,可以获得列对应的表信息

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...