[发明专利]结构化查询语句的多层解析方法、计算机设备及存储介质在审

专利信息
申请号: 202210300340.0 申请日: 2022-03-25
公开(公告)号: CN114756569A 公开(公告)日: 2022-07-15
发明(设计)人: 姚宏宇;朱朝强 申请(专利权)人: 北京友友天宇系统技术有限公司
主分类号: G06F16/242 分类号: G06F16/242;G06F16/245;G06F16/22
代理公司: 上海市锦天城律师事务所 31273 代理人: 汪妍瑜
地址: 100193 北京市海淀*** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 结构 查询 语句 多层 解析 方法 计算机 设备 存储 介质
【权利要求书】:

1.一种结构化查询语句的多层解析方法,其特征在于,包括:

根据SQL语句提取操作表名称;

根据所述操作表名称判断是否为跨库查询;

如果为非跨库查询,则根据目标数据源的查询语法对所述SQL语句进行语法转换,得到适配所述目标数据源的目标SQL语句;

如果为跨库查询,则将所述SQL语句发送至逻辑数据库的查询引擎。

2.根据权利要求1所述的方法,其特征在于,在根据SQL语句提取操作表名称之前,还包括:

根据SQL语句提取操作类型;

判断所述操作类型是否与预设类型匹配,预设类型包括:插入操作、删除操作、修改操作、排序操作或检索操作;

如果所述操作类型与预设类型匹配,根据SQL语句提取操作表名称。

3.根据权利要求2所述的方法,其特征在于,在根据SQL语句提取操作表名称之后,还包括:

根据所述操作类型、所述操作表名称以及缓存区中的用户权限信息进行用户的权限认证。

4.根据权利要求1所述的方法,其特征在于,在根据SQL语句提取操作表名称之后,还包括:

读取预先配置的字段权限变量;

如果所述字段权限变量为第一数值,根据所述SQL语句进行字段解析,确定目标字段;根据所述目标字段、所述SQL语句的操作类型以及缓存区中的用户权限信息进行用户的权限认证;

如果所述字段权限变量为第二数值,根据所述操作表名称判断是否为跨库查询。

5.根据权利要求4所述的方法,其特征在于,根据所述SQL语句进行字段解析,确定目标字段,包括:

根据预定义的统一SQL语句的语法对所述SQL语句进行转换,得到第一抽象语法树;

依次对所述第一抽象语法树中的节点进行遍历;

如果当前遍历的第一节点为字段名称节点的父节点,继续遍历;

如果当前遍历的第一节点为字段名称节点,提取所述字段名称节点中的目标字段;

如果当前遍历的第一节点不是字段名称节点的父节点且不是字段名称节点,返回上一个遍历的节点继续遍历。

6.根据权利要求1所述的方法,其特征在于,根据所述操作表名称判断是否为跨库查询,包括:

根据操作表名称与物理表的映射关系,确定物理表所属的数据源;

如果数据源不同,确定为跨库查询;

如果数据源相同,确定为非跨库查询。

7.根据权利要求1所述的方法,其特征在于,所述根据目标数据源的查询语法对所述SQL语句进行语法转换,得到适配所述目标数据源的目标SQL语句,包括:

根据所述SQL语句进行转换,得到第二抽象语法树;

根据逻辑数据库预定义的统一SQL语句的语法关键字和目标数据源SQL语句的语法关键字的映射关系对所述第二抽象语法树中的关键字节点内容进行替换;

根据逻辑数据库预定义的统一SQL函数和目标数据源SQL语句的函数的映射关系对所述第二抽象语法树中的函数节点内容进行语法转换,所述语法转换包含函数名的替换,函数参数的调整;

根据语法转换后的第二抽象语法树,确定目标SQL语句。

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

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

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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