数据库升级方法、装置及系统与流程

文档序号:12470324阅读:369来源:国知局
数据库升级方法、装置及系统与流程

本发明涉及数据库领域,具体而言,涉及一种数据库操作方法、装置及系统。



背景技术:

每一次程序版本的升级,都会伴随数据库版本的升级,现有技术使用<主版本号>.<子版本号>.<修订号>控制数据库版本,主版本号是在系统的重要发布或重大阶段会进行改变,比如每几个月一次。子版本号改变意味着数据库中加入了破坏性的改动(例如新的必需字段),这使得“旧的”应用程序与新的数据库架构不再兼容。修订号则是每次非破坏性的变动发生时(例如新的索引、新表、新的可选字段等等)进行递增的。

无论是主版本号、子版本号或修订号的每一次的改变,系统都将升级的数据库及脚本文件都与所述<主版本号>.<子版本号>.<修订号>匹配并储存。随着项目的增加,发布的版本累积量及任意两者的升级,特别是较久远的版本升级至最新版本,会超出管理者所承载的负荷。



技术实现要素:

有鉴于此,本发明实施例的目的在于提供一种数据库升级方法、装置及系统,以解决上述问题。

第一方面,本发明实施例提供一种数据库升级方法,所述方法包括:读取脚本文件,所述脚本文件包括数据库对象和/或数据;解析所述脚本文件,依次根据所述数据库对象或所述数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作,以完成数据库升级;删除所述脚本文件。

第二方面,本发明实施例提供一种数据库升级装置,所述装置包括:读取模块,用于读取脚本文件,所述脚本文件包括数据库对象和/或数据;升级模块,用于解析所述脚本文件,依次根据所述数据库对象或所述数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作,以完成数据库升级;删除模块,用于删除所述脚本文件。

第三方面,本发明实施例提供一种数据库升级系统,所述系统包括升级服务器,主数据库服务器以及子数据库服务器,所述升级服务器,用于读取脚本文件,所述脚本文件包括数据库对象和/或数据;解析所述脚本文件,依次根据所述数据库对象或所述数据的不同类型调用所述主数据库服务器上的数据库并对所述数据库进行预设的数据库操作,以完成所述主数据库服务器上数据库的升级;删除所述脚本文件;所述主数据库服务器,用于接受所述升级服务器的调用,完成所述主数据库服务器上数据库的升级;所述子数据库服务器,用于当所述主服务器完成数据库的升级操作后,完成所述子数据库服务器的数据同步。

与现有技术相比,本发明实施例提供的一种数据库升级方法、装置及系统,对于每一次的数据库升级,根据所述数据库对象或所述数据的不同类型进行预设的数据库操作来完成数据库升级操作,可以很简单的实现数据库的升级,进而方便产品版本的升级,降低了软件研发的时间成本,进一步的,下一次升级的执行预设操作后会直接覆盖上一次的数据库,因此对每一次数据库升级,只保留升级后的数据库,这样简化了数据库版本管理的流程,可大大缩短维护周期。

为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。

附图说明

为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。

图1是本发明实施例提供的升级服务器,主数据库服务器以及子数据库服务器的交互示意图。

图2是本发明实施例提供的升级服务器的方框示意图。

图3是本发明第一实施例提供的一种数据库升级方法的流程图。

图4是本发明第二实施例提供的一种数据库升级方法的部分流程图。

图5是本发明实施例提供的一种数据库升级装置的功能模块示意图。

具体实施方式

下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。

应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本发明的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性或时间先后。

如图1所示,图1示出了本发明实施例提供的升级服务器200,主数据库服务器100以及子数据库服务器300的交互示意图。所述升级服务器200通过网络500与所述主数据库服务器100进行通信连接。所述主数据库服务器100与一个或多个子数据库服务器300通过网络500进行通信连接,以进行数据通信或交互。

如图2所示,是所述升级服务器200的方框示意图。所述升级服务器200包括数据库升级装置210、存储器220、存储控制器230、处理器240。

所述存储器220、存储控制器230、处理器240各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。所述数据库升级装置210包括至少一个可以软件或固件(firmware)的形式存储于所述存储器中或固化在所述服务端200的操作系统(operating system,OS)中的软件功能模块。所述处理器240用于执行存储器220中存储的可执行模块,例如所述数据库升级装置210包括的软件功能模块或计算机程序。

其中,存储器220可以是,但不限于,随机存取存储器(Random Access Memory,RAM),只读存储器(Read Only Memory,ROM),可编程只读存储器(Programmable Read-Only Memory,PROM),可擦除只读存储器(Erasable Programmable Read-Only Memory,EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-Only Memory,EEPROM)等。其中,存储器220用于存储程序,所述处理器240在接收到执行指令后,执行所述程序,前述本发明实施例任一实施例揭示的流过程定义的服务端所执行的方法可以应用于处理器中,或者由处理器实现。

处理器240可能是一种集成电路芯片,具有信号的处理能力。上述的处理器可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(DSP)、专用集成电路(ASIC)、现成可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。

可以理解,图2所示的结构仅为示意,升级服务器200还可包括比图2中所示更多或者更少的组件,或者具有与图2所示不同的配置。图2中所示的各组件可以采用硬件、软件或其组合实现。

图3示出了本发明第一实施例提供的一种数据库升级方法的流程图,请参阅图3,本实施例描述的是升级服务器的处理流程,所述方法包括:

步骤S301,读取脚本文件,所述脚本文件包括数据库对象和/或数据。

其中,所述数据库对象包括表,索引,视图,图表,缺省值,规则,触发器,语法,函数等。

步骤S302,解析所述脚本文件,依次根据所述数据库对象或所述数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作,以完成数据库升级。

步骤S302的实施方式有多种,例如,可以一次性读入全部脚本文件的内容后,再逐条执行;当所述脚本文件包括多个子块,也可以分块进行读取,每读取一块,就按照块中的内容逐条执行。作为一种实施方式,可以在脚本文件中的每个子块结束时设置结束符,依次解析所述脚本文件的各个子块,每当读取到结束符时,依次根据所述数据库对象或所述数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作,直到所述脚本文件中的全部子块执行完毕。

进一步的,将所述数据库对象或所述数据分类的方式有多种,因此根据所述数据库对象或所述数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作的实施方式也有多种,下面介绍一种实施方式,但是,可以理解的是,并不局限于此。

将数据库对象划分为表类对象和非表类对象,并将所述数据划分为初始数据和业务数据。

所述表类对象,可以包括表,字段及索引。

所述非表类对象,是指所述数据库对象中除去表类对象之外的其它对象,例如存储过程,视图,函数,触发器等。

所述初始数据,是指是运行或启动一个应用程序必不可少的,例如引用数据,数据字典等。

所述业务数据,是指是通过应用程序的界面所创建、由外部数据源导入,或者是为了让开发者和测试人员可以开始工作而预先创建的示例数据。

数据库对象按照上述方式进行分类之后,升级服务器解析所述脚本文件,判断所述数据库对象的类型,当所述数据库对象为表类对象时,可以首先检测当前数据库中是否存在,以及检测属性差异等,然后进行更新操作,以弥补其差异;当所述数据库对象为非表类对象时,先执行删除操作再执行创建操作;当所述数据为初始数据时,执行插入操作;当所述数据为业务数据时,执行更新操作。

可以理解的是,对于架构上的升级,分为表类对象和非表类对象来区别对待,对于非表类对象才会需要删除后重新创建,大大减少了工作人员的工作量以及升级服务器运行的时间,而对于数据的升级,分为初始数据和业务数据,使得用户可以保留部分原有的数据库数据,开发人员只需控制好业务数据的变更,即可很简单的实现数据库的升级,进而方便产品版本的升级。

进一步的,可以预先给每个数据库分配一个对应的数据库标识,例如1对应SQL数据库,2对应MYSQL数据库等等,并不局限于此。若所述脚本文件中包括数据库标识符,所述升级服务器可以根据所述脚本文件中的数据库标识符,调用所述数据库标识符对应的数据库。通过这种方式,兼容了不同的数据库连接方式及主流的数据库平台,具有通用性,可移植性较强。

步骤S303,删除所述脚本文件。

数据库升级完成后,所述脚本文件无需再保存了,可以删除,删除后可以节约存储空间,也简化了各个版本管理的复杂性。

作为一种实施方式,在删除所述脚本文件之前,可以计算并存储所述脚本文件对应的数字签名,例如,计算所述脚本文件的MD5值。将所述MD5值存储下来,当下一次需要进行升级时,只需要将下一次升级的脚本计算个MD5值,并进行比对,如果一致,则可以不用进行升级。这种方式,能够大大节省时间。

本发明实施例提供的数据库升级方法,对于每一次的数据库升级,根据所述数据库对象或所述数据的不同类型进行预设的数据库操作来完成数据库升级操作,可以很简单的实现数据库的升级,进而方便产品版本的升级,降低了软件研发的时间成本,进一步的,下一次升级的执行预设操作后会直接覆盖上一次的数据库,因此对每一次数据库升级,只保留升级后的数据库,这样简化了数据库版本管理的流程,可大大缩短维护周期。

图4示出了本发明第二实施例提供的一种数据库升级方法的流程图,请参阅图4,本实施例描述的是升级服务器的处理流程,所述方法包括:

步骤S401,读取初始化脚本文件。

所述初始化脚本文件中包括用于新建一个数据库所必须的脚本内容。

步骤S402,根据所述初始化脚本文件,进行数据库安装操作。

作为一种实施方式,可以解析所述初始化脚本文件,依次根据所述初始化脚本文件中的数据库对象或数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作,以完成数据库安装。

步骤S403,删除所述初始化脚本文件。

优选的,可以在删除所述脚本文件之前,计算并存储所述初始化脚本文件对应的数字签名,以便升级时进行数字签名的比对。

可以理解的是,通过步骤S401至步骤S403,则完成了数据库的安装过程,即完成了数据库从无到有的过程。

步骤S404,读取脚本文件,所述脚本文件包括数据库对象和/或数据。

可以理解的是,所述脚本文件用于数据库升级,可以包括初始化脚本文件中的部分内容或者全部内容,所述脚本文件是在所述初始化文件的基础上进行修改,删除,新增一些新的脚本内容。

步骤S405,计算并存储所述脚本文件对应的数字签名。

计算所述数字签名方式有多种,例如HASH,MD5算法,此处就不再一一列举。

步骤S406,判断所述数字签名与前一次数据库升级时存储的数字签名是否一致。

如果不一致,执行步骤S407,否则,结束。

步骤S407,依次解析所述脚本文件的各个子块,每当读取到结束符时,依次根据所述数据库对象或所述数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作,直到所述脚本文件中的全部子块执行完毕,以完成数据库升级;删除所述脚本文件。

其中,所述脚本文件包括多个子块,每个子块结束时设置结束符,所述结束符可以用GO来表示。即所述升级服务器在每次读取并解析所述脚本文件时,每当读取到GO时,即理解按行执行刚刚读取的GO之前的所述脚本文件的子块,这种方式执行起来很快,使得数据库升级时,用户仍然能够正常使用数据库,而无需专门为了数据库升级,而断开用户与数据库的连接,进一步的提升了用户体验。

本发明实施例提供的数据库升级方法,完成了数据库的新建到升级的过程,对于每一次的数据库升级,根据所述数据库对象或所述数据的不同类型进行预设的数据库操作来完成数据库升级操作,可以很简单的实现数据库的升级,进而方便产品版本的升级,降低了软件研发的时间成本,进一步的,下一次升级的执行预设操作后会直接覆盖上一次的数据库,因此对每一次数据库升级,只保留升级后的数据库,这样简化了数据库版本管理的流程,可大大缩短维护周期。进一步的,在升级之前,通过数字签名的比对,节省了升级的时间,进一步的,使得数据库升级时,用户仍然能够正常使用数据库,而无需专门为了数据库升级,而断开用户与数据库的连接,进一步的提升了用户体验。

请参阅图5,是本发明实施例提供的图2所示的数据库升级装置210的功能模块示意图。所述数据库升级装置210运行于所述升级服务器200。所述数据库升级装置210包括读取模块211、升级模块212及删除模块213。

所述读取模块211,用于读取脚本文件,所述脚本文件包括数据库对象和/或数据;

所述升级模块212,用于解析所述脚本文件,依次根据所述数据库对象或所述数据的不同类型调用对应的数据库并对所述数据库进行预设的数据库操作,以完成数据库升级。

作为一种实施方式,所述数据库对象包括表类对象和非表类对象,所述数据包括初始数据和业务数据;所述根据所述数据库对象或所述数据的不同类型进行预设的数据库操作,包括:当所述数据库对象为表类对象时,进行更新操作;当所述数据库对象为非表类对象时,先执行删除操作再执行创建操作;当所述数据为初始数据时,执行插入操作;当所述数据为业务数据时,执行更新操作。

作为一种实施方式,所述脚本文件中包括数据库标识符,所述调用对应的数据库包括:根据所述脚本文件中的数据库标识符,调用所述数据库标识符对应的数据库。

所述删除模块213,用于删除所述脚本文件。

以上各模块可以是由软件代码实现,此时,上述的各模块可存储于中间升级服务器200的存储器220内。以上各模块同样可以由硬件例如集成电路芯片实现。

请参阅图1,是本发明实施例提供的一种数据库升级系统,所述系统包括升级服务器,主数据库服务器以及子数据库服务器。

所述升级服务器200,用于读取脚本文件,所述脚本文件包括数据库对象和/或数据;解析所述脚本文件,依次根据所述数据库对象或所述数据的不同类型调用所述主数据库服务器上的数据库并对所述数据库进行预设的数据库操作,以完成所述主数据库服务器上数据库的升级;删除所述脚本文件。

所述主数据库服务器100,用于接受所述升级服务器的调用,完成所述主数据库服务器上数据库的升级。

所述子数据库服务器300,用于当所述主服务器完成数据库的升级操作后,完成所述子数据库服务器的数据同步。

可以理解的是,通过这种分布式的数据库部署,以及主从服务器之间的数据同步,使得所述数据库升级系统能够适用于大数据的情况,进一步增大了应用的环境。

需要说明的是,本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。

本发明实施例所提供的数据库升级装置,其实现原理及产生的技术效果和前述方法实施例相同,为简要描述,装置实施例部分未提及之处,可参考前述方法实施例中相应内容。

在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。

另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。

所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务端,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。

以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。

以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1