[发明专利]一种数据库版本管理方法、系统及设备在审
申请号: | 202111130125.2 | 申请日: | 2021-09-26 |
公开(公告)号: | CN113778997A | 公开(公告)日: | 2021-12-10 |
发明(设计)人: | 俞天明;范渊;刘博 | 申请(专利权)人: | 杭州安恒信息技术股份有限公司 |
主分类号: | G06F16/21 | 分类号: | G06F16/21;G06F16/23 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 高勇 |
地址: | 310000 浙江省*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 数据库 版本 管理 方法 系统 设备 | ||
本发明公开了一种数据库版本管理方法、系统及设备,首先将多个待更新DDL文件中的一个作为当前待更新DDL文件,根据预设的数据库的DDL语法与数据库的对应关系和待更新数据库将当前待更新DDL文件解析成DDL语句在待更新数据库中执行,若执行失败,则会记录当前待更新DDL文件的版本号,然后将下一个待更新DDL文件作为当前待更新DDL文件进行解析,直至所有待更新DDL文件全部被解析完毕。使得在多人协同开发的情况下,DDL语句执行失败以后,用户根据记录的执行失败的当前待更新DDL文件的版本号能够准确的定位,提高了工作效率且适用于行式数据库和列式数据库的版本管理。
技术领域
本发明涉及数据管理领域,特别是涉及一种数据库版本管理方法、系统及设备。
背景技术
随着企业业务的迅速拓展,单一数据库难以满足业务需求,往往需要引入不同的数据库,例如,使用ElasticSearch实现大数据下的全文检索,使用ClickHouse实现大宽表的快速查询和分析等。企业在对待更新数据库进行版本管理时,通过在待更新数据库中执行待更新DDL(Data Definition Language,数据库模式定义语言)文件解析成的DDL语句对待更新数据库中的文件进行操作。企业在对新版行式数据库及列式数据库进行多人协同开发时,会上传多个待更新DDL文件,执行失败后,系统仅会报错而无法定位执行失败的待更新DDL文件,产生了大量的排查任务,降低了工作效率。
发明内容
本发明的目的是提供一种数据库版本管理方法、系统及设备,在多人协同开发的情况下,DDL语句执行失败以后,用户根据记录的执行失败的当前待更新DDL文件的版本号能够准确的定位,提高了工作效率且适用于行式数据库和列式数据库的版本管理。
为解决上述技术问题,本发明提供了一种数据库版本管理方法,包括:
S1:确定待更新数据库的多个待更新DDL文件中的一个作为当前待更新DDL文件;
S2:根据预设的数据库的DDL语法与数据库的对应关系和所述待更新数据库对所述当前待更新DDL文件进行解析,得到DDL语句;
S3:在所述待更新数据库中执行所述DDL语句;
S4:判断所述DDL语句是否执行成功,若是,进入S5,若否,进入S7;
S5:判断多个所述待更新DDL文件是否全部解析完毕,若否,进入S6,否则,进入S8;
S6:从多个所述待更新DDL文件中未执行的所述待更新DDL文件中确定下一个DDL文件作为所述当前待更新DDL文件,返回S2;
S7:记录所述当前待更新DDL文件的版本号及DDL语句执行失败的操作记录,返回S5;
S8:结束更新。
优选的,记录所述当前待更新DDL文件的版本号及DDL语句执行失败的操作记录,包括:
记录所述当前待更新DDL文件的版本号及DDL语句执行失败的操作记录到所述待更新数据库中的版本管理模块中。
优选的,S4与S5之间还包括:
若判定所述DDL语句执行成功,则将所述当前待更新DDL文件的版本号记录到所述版本管理模块中作为历史版本号。
优选的,在S1之前,还包括:
获取预设目录下的所述待更新数据库的所有DDL文件的版本号;所有所述DDL文件包括已更新DDL文件和/或待更新DDL文件;
获取所述待更新数据库的所有所述历史版本号;
判断是否存在版本号与所有所述历史版本号均不同的DDL文件;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州安恒信息技术股份有限公司,未经杭州安恒信息技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111130125.2/2.html,转载请声明来源钻瓜专利网。