[发明专利]一种分库分表模式下逻辑SQL语句翻译方法和装置在审
申请号: | 201711000959.5 | 申请日: | 2017-10-24 |
公开(公告)号: | CN109697068A | 公开(公告)日: | 2019-04-30 |
发明(设计)人: | 龚家兵 | 申请(专利权)人: | 中移(苏州)软件技术有限公司;中国移动通信集团公司 |
主分类号: | G06F8/40 | 分类号: | G06F8/40;G06F8/41 |
代理公司: | 北京同达信恒知识产权代理有限公司 11291 | 代理人: | 郭润湘 |
地址: | 215163 江*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 分表 语法分析树 方法和装置 翻译 输出逻辑 语句分析 预设 匹配 输出 | ||
1.一种分库分表模式下逻辑SQL语句翻译方法,其特征在于,所述方法包括:
接收并输出逻辑SQL语句;
对所述输出的逻辑SQL语句进行语句分析,获取所述逻辑SQL语句的语法分析树;
对所述语法分析树中表名与预设的分库分表策略进行匹配,获取所述语法分析树中表名的分库分表信息;
基于所述分库分表信息,将所述逻辑SQL语句翻译为物理SQL语句。
2.如权利要求1所述的方法,其特征在于,所述对所述语法分析树中表名与预设的分库分表策略进行匹配,获取所述语法分析树中表名的分库分表信息,包括:
判断所述语法分析树中的表名是否与预设分库策略相匹配,其中,所述预设的分库分表策略中包括所述预设分库策略和预设分表策略;
在为是时,从所述预设分库策略中获取与所述语法分析树中的表名匹配的第一分库信息;
从所述预设分表策略中获取与所述语法分析树中的表名匹配的第一分表信息。
3.如权利要求2所述的方法,其特征在于,所述基于所述分库分表信息,将所述逻辑SQL语句翻译为物理SQL语句,包括:
基于所述第一分库信息和所述第一分表信息,获取与所述语法分析树中表名对应的第一物理表名;
利用所述第一物理表名替换所述逻辑SQL语句中的表名从而获取第一物理SQL语句。
4.如权利要求3所述的方法,其特征在于,在所述判断所述语法分析树中表名是否与预设分库策略相匹配之后,所述方法还包括:
若所述语法分析树中表名与所述预设分库策略不匹配,判断所述语法分析树中表名是否与预设分表策略相匹配;
在为是时,从所述预设分表策略中获取与所述语法分析树中的表名匹配的第二分表信息。
5.如权利要求4所述的方法,其特征在于,所述基于所述分库分表信息,将所述逻辑SQL语句翻译为物理SQL语句,包括:
基于所述第二分表信息,获取与所述语法分析树中的表名对应的第二物理表名;
利用所述第二物理表名替换所述逻辑SQL语句中的表名,从而获取第二物理SQL语句。
6.如权利要求1-5任一项所述的方法,其特征在于,在所述接收并输出逻辑SQL语句之前,所述方法还包括:
进行分库分表策略配置,从而存储所述预设的分库分表策略。
7.如权利要求1-5任一项所述的方法,其特征在于,在所述基于所述分库分表信息,将所述逻辑SQL语句翻译为物理SQL语句之后,所述方法还包括:
输出所述物理SQL语句和所述物理SQL语句的物理库信息和/或物理表信息。
8.一种分库分表模式下逻辑SQL语句翻译装置,其特征在于,所述装置包括:
接收模块,用于接收并输出的逻辑SQL语句;
第一获取模块,用于对所述输出的逻辑SQL语句进行语句分析,获取所述逻辑SQL语句的语法分析树;
第二获取模块,用于对所述语法分析树中表名与预设的分库分表策略进行匹配,获取所述语法分析树中表名的分库分表信息;
翻译模块,用于基于所述分库分表信息,将所述逻辑SQL语句翻译为物理SQL语句。
9.如权利要求8所述的装置,其特征在于,所述第二获取模块包括:
判断子模块,用于判断所述语法分析树中的表名是否与预设分库策略相匹配,其中,所述预设的分库分表策略中包括所述预设分库策略和预设分表策略;
第一获取子模块,用于在为是时,从所述预设分库策略中获取与所述语法分析树中的表名匹配的第一分库信息;
第二获取子模块,用于从所述预设分表策略中获取与所述语法分析树中的表名匹配的第一分表信息。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中移(苏州)软件技术有限公司;中国移动通信集团公司,未经中移(苏州)软件技术有限公司;中国移动通信集团公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711000959.5/1.html,转载请声明来源钻瓜专利网。
- 上一篇:数据打包方法及装置
- 下一篇:一种H5应用的打包方法及终端