[发明专利]一种支持多方言SQL血缘解析的语义分析方法在审

专利信息
申请号: 202110887535.5 申请日: 2021-08-03
公开(公告)号: CN113326286A 公开(公告)日: 2021-08-31
发明(设计)人: 凌立刚;陈科皓;孙锐 申请(专利权)人: 杭州量之智能科技有限公司
主分类号: G06F16/242 分类号: G06F16/242
代理公司: 杭州云睿专利代理事务所(普通合伙) 33254 代理人: 张骁敏
地址: 310000 浙江省杭州市*** 国省代码: 浙江;33
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 支持 多方 sql 血缘 解析 语义 分析 方法
【权利要求书】:

1.一种支持多方言SQL血缘解析的语义分析方法,其特征在于,包括以下步骤:

步骤1,对SQL进行词法分析将SQL序列转化成单词序列,再进行语法分析得到对应的抽象语法分析树;

步骤2,通过归纳不同种类SQL的语义特征,归纳不同种类SQL语义间的关联关系、从属关系,提取不同种类SQL在血缘解析中所需要的语义信息,根据提取出的SQL的语义信息、以及生成的所述抽象语法分析树的树形结构形成一种适用不同种类SQL做语义分析的语义分析模型,并提供设置输入接口、输出接口分别作为语法分析和血缘解析的中间结构;

步骤3,对于新的SQL,通过步骤1的方式生成抽象语法分析树,再遍历抽象语法分析树,获取抽象语法分析树节点中的语义信息,根据抽象语法分析树上节点包含的单词序列的语义信息,将单词序列拆分,通过调用所述输入接口分别填充至所述语义分析模型中;

步骤4,调用所述语义分析模型的所述输出接口,获取新的SQL的语义信息以进行进一步的血缘解析。

2.根据权利要求1所述的一种支持多方言SQL血缘解析的语义分析方法,其特征在于,所述步骤1中的抽象语法分析树的生成过程包括:

步骤1.1,对SQL按照SQL语言的词法规则识别各类单词,并产生相应单词的属性字,最终将SQL序列转换成属性字的单词序列;

步骤1.2,根据SQL的语法规则设计一套EBNF范式,对传入的所述单词序列按照语法规则进行匹配,生成抽象语法分析树。

3.根据权利要求2所述的一种支持多方言SQL血缘解析的语义分析方法,其特征在于,所述步骤1.1需将输入中的无效属性字进行过滤,只保留对SQL语法分析有效的属性字的单词序列。

4.根据权利要求1所述的一种支持多方言SQL血缘解析的语义分析方法,其特征在于,所述步骤2还包括:

调用所述输入接口实现对所述语义分析模型进行单词序列的填充,调用所述输出接口实现获取所需语义类型下的实际单词序列,为血缘分析提供单词序列的语法含义。

5.根据权利要求1所述的一种支持多方言SQL血缘解析的语义分析方法,其特征在于,步骤3中遍历抽象语法分析树的遍历方法包括:

以一个完整的数据定义语言或数据操作语言为单元,每当遍历到所述抽象语法分析树中对应的叶子节点,在退出单元节点时将返回对应单元所属的所有表结构,表结构中包含了所有叶子节点的语义信息;

根据所述叶子节点的语义信息,新建一个对应语义的语义分析模型的实例对象,再通过调用所述语义分析模型提供的方法,填充好实例对象的属性后将该实例对象作为返回值。

6.根据权利要求5所述的一种支持多方言SQL血缘解析的语义分析方法,其特征在于,步骤4以作为返回值的实例对象作为输入,根据实例对象的类型确定语义类型,通过调用所述输出接口获得对应语义类型下的实体内容,即实体获得对应语义类型下的实际单词序列。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州量之智能科技有限公司,未经杭州量之智能科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/202110887535.5/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top