ZGLanguage 解析SQL数据血缘 之 提取select语句中的源表名

假设存在 SQL代码 如下:

sql 复制代码
SELECT CL.OBJECTNO
     , AL.PAYDATE
  FROM NYBDP.O_SS_CL_LOAN_ACCT_STATIS CL
 inner JOIN O_CWWS_ACCT_LOAN AL
    ON 1=1
  LEFT out JOIN NYBDP.O_CWWS_BUSINESS_DUEBILL BD
    ON 1=1
  LEFT JOIN O_CWWS_BUSINESS_CONTRACT BC
    ON 1=1
;

若要提取以上SQL代码中的源表名,可配置语法标注"源表"如下:

sql 复制代码
__DEF_CASE_SENSITIVE__    N

__DEF_PATH__    __SELECT__
1             : x1            @          | select
N             : x2            @          | __OTH_COL__
e             : x3            @          | ,
1             : x4            @          | from
              : x5            @          | __TABLE_NAME__
N             : x6            @          | __JOIN_TABLE__


__DEF_SUB_PATH__   __OTH_COL__
1       : x1          | __NAME__
        : x2          | .
        : x3          | __NAME__


__DEF_SUB_PATH__       __TABLE_NAME__
1        : 源表           @           | __NAME__
+        : schema         @           | __NAME__
         : pp             @           | .
         : 源表_2         @           | __NAME__
1        : as             @ CAN_SKIP  | as
         : 源表别名       @ CAN_SKIP  | __NAME__


__DEF_SUB_PATH__    __JOIN_TABLE__
1             : x0      @                | join
+             : x1      @                | inner
              : x2      @                | join
+             : x5      @                | left
              : x6      @ CAN_SKIP       | out
              : x7      @                | join
+             : x12     @                | right
              : x13     @ CAN_SKIP       | out
              : x14     @                | join
+             : x17     @                | full
              : x18     @ CAN_SKIP       | out
              : x19     @                | join
+             : x20     @                | ,
1             : x21     @                | __TABLE_NAME__
              : x22     @                | on
              : x23     @                | 1=1


__DEF_STR__   __NAME__
<1,100>
[1,1]ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz_??
[0,100]ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_??
[NO] select inner left join on from where group order by having union all with as table

根据语法配置解析结果(导入Excel)如下所示:

由以上解析结果红色部分所示,根据 标注 列进行"源表"筛选,可以得到select语句中的4张源表名。

相关推荐
Nandeska5 小时前
15、基于MySQL的组复制
数据库·mysql
CodeSheep程序羊5 小时前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展
L***一6 小时前
大数据技术专业中专生职业发展路径探析
大数据
编程小白20266 小时前
从 C++ 基础到效率翻倍:Qt 开发环境搭建与Windows 神级快捷键指南
开发语言·c++·windows·qt·学习
woshikejiaih6 小时前
**播客听书与有声书区别解析2026指南,适配不同场景的音频
大数据·人工智能·python·音视频
无忧智库6 小时前
某市“十五五“智慧气象防灾减灾精准预报系统建设方案深度解读 | 从“看天吃饭“到“知天而作“的数字化转型之路(WORD)
大数据·人工智能
AllData公司负责人6 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
acrelwwj6 小时前
智慧照明新引擎,ASL600 4GWJ开启城市照明精细化管理新时代
大数据·经验分享·物联网
加油,小猿猿6 小时前
Java开发日志-双数据库事务问题
java·开发语言·数据库
.小墨迹6 小时前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu