[发明专利]一种SQL代码转换方法及装置有效
申请号: | 201610099219.0 | 申请日: | 2016-02-23 |
公开(公告)号: | CN107103007B | 公开(公告)日: | 2020-09-15 |
发明(设计)人: | 蔡聪;李剑平 | 申请(专利权)人: | 菜鸟智能物流控股有限公司 |
主分类号: | G06F16/2453 | 分类号: | G06F16/2453 |
代理公司: | 北京博思佳知识产权代理有限公司 11415 | 代理人: | 林祥 |
地址: | 开曼群岛大开曼岛*** | 国省代码: | 暂无信息 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 sql 代码 转换 方法 装置 | ||
1.一种SQL代码转换方法,其特征在于,该方法包括:
对待转换的SQL原代码段进行解析,确定原代码段的语法结构以及原代码段中使用到的表名、表中字段名;
根据预设的转换需求信息,确定所述原代码段中的待替换表名及待替换字段名,所述待替换字段为待替换表中的字段;所述转换需求信息中包括:需要替换的表名文本的替换前后对应关系、以及需要替换的字段名文本的替换前后对应关系;
在所述原代码段中存在join操作关键字的情况下,判断待替换表是join操作的直接操作对象还是间接操作对象;
根据判断结果,对待替换表名及待替换字段名进行文本替换:
如果待替换表是join操作的直接操作对象,则将所述原代码段中的待替换表名文本替换为待替换表对应的SQL子查询代码,进一步根据所述转换需求信息,对替换后代码段中的待替换表名及待替换字段名进行文本替换;
如果待替换表是join操作的间接操作对象,则直接根据所述转换需求信息,对所述原代码段中的待替换表名及待替换字段名进行文本替换。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
进行字段名文本替换之后,针对替换后的查询结果字段名添加字段类型转换代码,转换的目标字段类型根据替换前的字段类型确定。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
进行字段名文本替换之后,针对替换后的字段名添加别名指定代码,所指定的字段别名根据所述原代码段中对该字段的使用需求确定。
4.根据权利要求1所述的方法,其特征在于,所述将所述原代码段中的待替换表名文本替换为待替换表对应的SQL子查询代码,包括:
确定在所述原代码段中需要用到的待替换表字段;
针对所确定出的字段,生成对应的SQL子查询代码;
将所述原代码段中的待替换表名文本替换为所生成的SQL子查询代码。
5.根据权利要求1所述的方法,其特征在于,所述方法还包括:
将所述原代码段join条件中针对待替换表的单表过滤条件,改写为所述SQL子查询代码的过滤条件、并移至所述SQL子查询代码中。
6.一种SQL代码转换装置,其特征在于,该装置包括:
解析模块,用于对待转换的SQL原代码段进行解析,确定原代码段的语法结构以及原代码段中使用到的表名、表中字段名;
待替换文本确定模块,用于根据预设的转换需求信息,确定所述原代码段中的待替换表名及待替换字段名,所述待替换字段为待替换表中的字段;所述转换需求信息中包括:需要替换的表名文本的替换前后对应关系、以及需要替换的字段名文本的替换前后对应关系;
判断模块,用于在所述原代码段中存在join操作关键字的情况下,判断待替换表是join操作的直接操作对象还是间接操作对象;
替换模块,用于根据判断结果对待替换表名及待替换字段名进行文本替换:在待替换表是join操作的直接操作对象的情况下,将所述原代码段中的待替换表名文本替换为待替换表对应的SQL子查询代码,进一步根据所述转换需求信息,对替换后代码段中的待替换表名及待替换字段名进行文本替换;
在待替换表是join操作的间接操作对象的情况下,直接根据所述转换需求信息,对所述原代码段中的待替换表名及待替换字段名进行文本替换。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于菜鸟智能物流控股有限公司,未经菜鸟智能物流控股有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201610099219.0/1.html,转载请声明来源钻瓜专利网。