[发明专利]数据库中表的变更方法及装置有效
| 申请号: | 201910886004.7 | 申请日: | 2019-09-19 |
| 公开(公告)号: | CN110633284B | 公开(公告)日: | 2022-04-29 |
| 发明(设计)人: | 陈光柳;温建波;郑培龙;吴宏招 | 申请(专利权)人: | 中国工商银行股份有限公司 |
| 主分类号: | G06F16/22 | 分类号: | G06F16/22;G06F16/2455 |
| 代理公司: | 北京三友知识产权代理有限公司 11127 | 代理人: | 孙乳笋;周永君 |
| 地址: | 100140 北*** | 国省代码: | 北京;11 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 数据库 中表 变更 方法 装置 | ||
1.一种数据库中表的变更方法,其特征在于,包括:
获取针对数据库中的目标表的变更指令,该变更指令中包含有对应的变更信息;所述变更指令通过将用户在表登记系统上登记的变更信息转换得到;
采用预设的DDL语法规则,并基于所述数据库中的目标表和对应的变更信息生成DDL脚本;
自动调取并执行所述DDL脚本,以对所述数据库中的目标表进行变更。
2.根据权利要求1所述的数据库中表的变更方法,其特征在于,在基于所述数据库中的目标表和对应的表变更信息生成DDL脚本之后,还包括:
将所述DDL脚本进行存储并在预设列表中生成所述DDL脚本对应的查询条目。
3.根据权利要求2所述的数据库中表的变更方法,其特征在于,在所述自动调取并执行所述DDL脚本以对所述数据库中的目标表进行变更之后,还包括:
将所述变更后的目标表进行程序打包处理生成版本包,并对所述版本包进行版本部署。
4.根据权利要求3所述的数据库中表的变更方法,其特征在于,在对所述版本包进行版本部署之后,还包括:
根据所述版本包进行版本部署结果对变更后的目标表所对应的状态进行标记;
其中,若版本部署的结果为成功,则所述目标表所对应的状态标记为已安装;若版本部署的结果为失败,则目标表所对应的状态标记为安装失败。
5.根据权利要求1所述的数据库中表的变更方法,其特征在于,所述变更信息,包括:新增信息、修改信息和删除信息中的至少一种;
其中,所述新增信息包括:表基本数据、字段数据、索引数据和约束数据中至少一种;所述修改信息包括:对表基本数据、字段数据、索引数据和约束数据中至少一种进行修改的信息。
6.根据权利要求1所述的数据库中表的变更方法,其特征在于,所述采用预设的DDL语法规则并基于所述数据库中的目标表和对应的变更信息生成DDL脚本,包括:
以所述数据库中的目标表为基准,将所述变更信息转换为DDL语句;
采用预设的DDL语法规则并基于所述DDL语句生成DDL脚本。
7.根据权利要求1所述的数据库中表的变更方法,其特征在于,所述DDL脚本包括:增量DDL脚本和/或发布DDL脚本;
相对应的,对所述数据库中的目标表进行变更,包括:
自动调取并执行所述增量DDL脚本对测试环境下的数据库中的目标表进行变更;或者,
自动调取并执行所述发布DDL脚本对生产环境下的数据库中的目标表进行变更。
8.一种数据库中表的变更装置,其特征在于,包括:
获取单元,用于获取针对数据库中的目标表的变更指令,该变更指令中包含有对应的变更信息;所述变更指令通过将用户在表登记系统上登记的变更信息转换得到;
转换单元,用于采用预设的DDL语法规则,并基于所述数据库中的目标表和对应的变更信息生成DDL脚本;
变更单元,用于自动调取并执行所述DDL脚本,以对所述数据库中的目标表进行变更。
9.根据权利要求8所述的数据库中表的变更装置,其特征在于,还包括:
查询单元,用于将所述DDL脚本进行存储并在预设列表中生成所述DDL脚本对应的查询条目。
10.根据权利要求9所述的数据库中表的变更装置,其特征在于,还包括:
部署单元,用于将所述变更后的目标表进行程序打包处理生成版本包,并对所述版本包进行版本部署。
11.根据权利要求10所述的数据库中表的变更装置,其特征在于,还包括:
标记单元,用于根据所述版本包进行版本部署结果对变更后的目标表所对应的状态进行标记;
其中,若版本部署的结果为成功,则所述目标表所对应的状态标记为已安装;若版本部署的结果为失败,则目标表所对应的状态标记为安装失败。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国工商银行股份有限公司,未经中国工商银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910886004.7/1.html,转载请声明来源钻瓜专利网。





