[发明专利]基于变更代码的数据表确定方法以及装置有效
| 申请号: | 201910906315.5 | 申请日: | 2019-09-24 |
| 公开(公告)号: | CN110659293B | 公开(公告)日: | 2022-02-11 |
| 发明(设计)人: | 常旭亮 | 申请(专利权)人: | 支付宝(杭州)信息技术有限公司 |
| 主分类号: | G06F16/22 | 分类号: | G06F16/22;G06F16/25;G06F8/65;G06F8/71;G06F11/07 |
| 代理公司: | 北京智信禾专利代理有限公司 11637 | 代理人: | 吴肖肖 |
| 地址: | 310013 浙江省杭州市*** | 国省代码: | 浙江;33 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 基于 变更 代码 数据表 确定 方法 以及 装置 | ||
1.一种基于变更代码的数据表确定方法,包括:
在接收到针对应用提交的更新请求的情况下,获取针对所述应用提交的变更代码;
基于所述变更代码,确定所述变更代码在变更文件中对应的变更行号,并确定所述变更行号所属的变更方法,从解析出的应用方法与数据库层接口之间的调用关系中,查找所述变更方法调用的数据库层接口作为变更数据库层接口;
在获取到的根据所述应用的目标代码文件解析出的数据库层接口与数据表之间的映射关系中,查找所述变更数据库层接口映射的数据表,作为所述变更代码在所述应用中对应的变更数据表。
2.根据权利要求1所述的基于所述变更代码,确定所述变更代码在变更文件中对应的变更行号,并确定所述变更行号所属的变更方法,从解析出的应用方法与数据库层接口之间的调用关系中,查找所述变更方法调用的数据库层接口作为变更数据库层接口,包括:
将所述变更代码按照变更类型分为代码类型以及非代码类型;
获取所述代码类型对应的代码在代码变更文件中对应的代码变更行号列表;
基于所述代码所在的所述代码变更文件以及所述代码变更行号列表确定所述代码所属的代码变更方法列表;
将所述代码变更行号列表、代码变更方法列表以及所述非代码类型对应的变更信息进行组装生成变更结构;
将所述变更结构与解析所述目标代码文件获得的所述应用的应用方法之间的调用关系结构进行匹配,获得所述变更代码对应的所述变更数据库层接口。
3.根据权利要求1所述的基于变更代码的数据表确定方法,所述数据库层接口与数据表之间的映射关系,采用如下方式确定:
通过对所述目标代码文件进行解析,获得所述目标代码文件中的数据库层接口,以及所述数据库层接口对应的SQL标识;
将针对基于所述目标代码文件中SQL配置文件解析出的SQL语句生成的抽象语法树进行遍历,获得所述SQL语句对应的SQL语句标识以及数据表;
通过所述SQL标识以及所述SQL语句标识将所述数据库层接口以及所述SQL语句对应的数据表进行关联,建立所述数据库层接口与数据表之间的映射关系。
4.根据权利要求3所述的基于变更代码的数据表确定方法,所述通过对所述目标代码文件进行解析,获得所述目标代码文件中的数据库层接口,以及所述数据库层接口对应的SQL标识步骤执行之前,还包括:
在接收到针对所述应用的注册请求的情况下,通过将所述应用的应用信息写入注册表的方式完成注册;
通过消息监听器,监听解析所述映射关系的解析任务的触发消息;
基于所述触发消息,根据所述注册表中的所述应用名称将所述目标代码文件拉取至目标服务器。
5.根据权利要求3所述的基于变更代码的数据表确定方法,所述通过所述SQL标识以及所述SQL语句标识将所述数据库层接口以及所述SQL语句对应的数据表进行关联,建立所述数据库层接口与数据表之间的映射关系步骤执行之后,还包括:
将所述映射关系以映射关系表的形式在数据库进行存储;
所述在获取到的根据所述应用的目标代码文件解析出的数据库层接口与数据表之间的映射关系中,查找所述变更数据库层接口映射的数据表,作为所述变更代码在所述应用中对应的变更数据表步骤执行之前,在所述数据库中读取所述映射关系表。
6.根据权利要求1所述的基于变更代码的数据表确定方法,所述更新请求包括:所述应用的应用名称、代码仓库地址、起始代码版本、目标代码版本;
所述获取针对所述应用提交的变更代码,包括:
在所述代码仓库地址指向的代码仓库中,获取在目标代码版本与起始代码版本之间与所述应用名称对应的变更代码。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于支付宝(杭州)信息技术有限公司,未经支付宝(杭州)信息技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910906315.5/1.html,转载请声明来源钻瓜专利网。





