[发明专利]一种支持多方言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以作为返回值的实例对象作为输入,根据实例对象的类型确定语义类型,通过调用所述输出接口获得对应语义类型下的实体内容,即实体获得对应语义类型下的实际单词序列。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州量之智能科技有限公司,未经杭州量之智能科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110887535.5/1.html,转载请声明来源钻瓜专利网。
- 上一篇:用于检测镶嵌宝石类首饰稳固性的检测装置及检测方法
- 下一篇:一种甲醛去除装置





