基于流程引擎的SQL发布方法及系统技术方案

技术编号:27656254 阅读:17 留言:0更新日期:2021-03-12 14:18
本发明专利技术提供一种基于流程引擎的SQL发布方法及系统,该方法包括:获取为应用程序配置的发布任务中的SQL发布包,根据所述SQL发布包下的SQL文件之间的分隔符,获取每条SQL文件;逐条执行SQL文件,判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致;其中,当前执行的SQL文件的预期执行结果位于紧邻当前执行的SQL文件之后的分隔符后面。本发明专利技术自动确定SQL文件的执行结果是否符合预期,简单易用,对发布人员的要求低,效率高,且不容易出错。

【技术实现步骤摘要】
基于流程引擎的SQL发布方法及系统
本专利技术涉及SQL发布
,尤其涉及一种基于流程引擎的SQL发布方法及系统。
技术介绍
应用程序的发布往往伴随着SQL(StructuredQueryLanguage,结构化查询语言)的发布。传统的SQL发布都是通过人为手动执行SQL或者是通过脚本来执行,执行的成功与失败都需要人为来判断。目前大部分的SQL发布都是通过手工的方式发布,与应用程序的发布是分隔开的。SQL发布完成后必须手工去验证SQL的执行结果是否符合预期。需要发布人员非常了解SQL执行的结果预期。但由于发布人员和开发人员往往是不同的人员,SQL发布完成之后发布人员不能准确判定执行的结果是否符合预期。综上所述,通过人工方式进行SQL发布操作繁琐,执行结果是否符合预期不好判断,且容易出错,对发布人员的要求较高。
技术实现思路
本专利技术提供一种基于流程引擎的SQL发布方法及系统,用以解决现有技术中通过人工方式进行SQL发布操作繁琐,执行结果是否符合预期不好判断,且容易出错,对发布人员的要求较高的缺陷,实现自动判断SQL的执行结果是否符合预期。本专利技术提供一种基于流程引擎的SQL发布方法,包括:获取为应用程序配置的发布任务中的SQL发布包,根据所述SQL发布包下的SQL文件之间的分隔符,获取每条SQL文件;逐条执行SQL文件,判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致;其中,当前执行的SQL文件的预期执行结果位于紧邻当前执行的SQL文件之后的分隔符后面。根据本专利技术提供的一种基于流程引擎的SQL发布方法,所述判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致,之后还包括:若当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果不一致,则返回当前执行的SQL文件的错误码;根据预先为所述错误码配置的是否忽略选项,确定是否继续执行当前执行的SQL文件的下一条SQL文件。根据本专利技术提供的一种基于流程引擎的SQL发布方法,所述根据预先为所述错误码配置的是否忽略选项,确定是否继续执行当前执行的SQL文件的下一条SQL文件,包括:若预先为所述错误码配置的是否忽略选项为忽略,则忽略所述错误码,继续执行当前执行的SQL文件的下一条SQL文件;若预先为所述错误码配置的是否忽略选项为不忽略,则不忽略所述错误码,停止执行当前执行的SQL文件的下一条SQL文件。根据本专利技术提供的一种基于流程引擎的SQL发布方法,所述判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致,之后还包括:若当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果一致,则继续执行当前执行的SQL文件的下一条SQL文件。根据本专利技术提供的一种基于流程引擎的SQL发布方法,所述判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致,之后还包括:显示当前执行的SQL文件的执行日志,以供用户根据所述执行日志判断是否继续执行当前执行的SQL文件的下一条SQL文件;若获取到用户点击跳过当前执行的SQL文件的操作,则继续执行当前执行的SQL文件的下一条SQL文件;若获取到用户点击终止SQL文件的发布操作,则停止执行当前执行的SQL文件的下一条SQL文件。本专利技术还提供一种基于流程引擎的SQL发布系统,包括:获取模块,用于获取为应用程序配置的发布任务中的SQL发布包,根据所述SQL发布包下的SQL文件之间的分隔符,获取每条SQL文件;判断模块,用于逐条执行SQL文件,判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致;其中,当前执行的SQL文件的预期执行结果位于紧邻当前执行的SQL文件之后的分隔符后面。根据本专利技术提供的一种基于流程引擎的SQL发布系统,还包括确定模块,所述确定模块用于:若当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果不一致,则返回当前执行的SQL文件的错误码;根据预先为所述错误码配置的是否忽略选项,确定是否继续执行当前执行的SQL文件的下一条SQL文件。根据本专利技术提供的一种基于流程引擎的SQL发布系统,所述确定模块用于:若预先为所述错误码配置的是否忽略选项为忽略,则忽略所述错误码,继续执行当前执行的SQL文件的下一条SQL文件;若预先为所述错误码配置的是否忽略选项为不忽略,则不忽略所述错误码,停止执行当前执行的SQL文件的下一条SQL文件。本专利技术还提供一种电子设备,包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述任一种所述基于流程引擎的SQL发布方法的步骤。本专利技术还提供一种非暂态计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现如上述任一种所述基于流程引擎的SQL发布方法的步骤。本专利技术提供的基于流程引擎的SQL发布方法及系统,通过使用SQL文件之间的分隔符对SQL文件进行拆分,并在每条SQL文件后面的分隔符后面添加其预期执行结果,在执行完单条SQL文件后,判断其实际执行结果与预期执行结果是否一致,从而自动确定SQL文件的执行结果是否符合预期,简单易用,对发布人员的要求低,效率高,且不容易出错。附图说明为了更清楚地说明本专利技术或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作一简单地介绍,显而易见地,下面描述中的附图是本专利技术的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。图1是本专利技术提供的基于流程引擎的SQL发布方法的流程示意图;图2是本专利技术提供的基于流程引擎的SQL发布系统的结构示意图;图3是本专利技术提供的电子设备的结构示意图。具体实施方式为使本专利技术的目的、技术方案和优点更加清楚,下面将结合本专利技术中的附图,对本专利技术中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本专利技术一部分实施例,而不是全部的实施例。基于本专利技术中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本专利技术保护的范围。下面结合图1描述本专利技术的一种基于流程引擎的SQL发布方法,包括:步骤101,获取为应用程序配置的发布任务中的SQL发布包,根据所述SQL发布包下的SQL文件之间的分隔符,获取每条SQL文件;在应用程序和SQL发布之前,纳管数据库设备,并对SQL发布包版本进行管理。创建到数据库服务器的JDBC(JavaDatabaseConnectivity,Java数据库连接)连接,使用JDBC协议与设备上的数据库建立连接,并监控数据库的连接状态。创建应用程序下的发布包版本,上传SQL发布包到版本库,更新至可用本文档来自技高网...

【技术保护点】
1.一种基于流程引擎的SQL发布方法,其特征在于,包括:/n获取为应用程序配置的发布任务中的SQL发布包,根据所述SQL发布包下的SQL文件之间的分隔符,获取每条SQL文件;/n逐条执行SQL文件,判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致;其中,当前执行的SQL文件的预期执行结果位于紧邻当前执行的SQL文件之后的分隔符后面。/n

【技术特征摘要】
1.一种基于流程引擎的SQL发布方法,其特征在于,包括:
获取为应用程序配置的发布任务中的SQL发布包,根据所述SQL发布包下的SQL文件之间的分隔符,获取每条SQL文件;
逐条执行SQL文件,判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致;其中,当前执行的SQL文件的预期执行结果位于紧邻当前执行的SQL文件之后的分隔符后面。


2.根据权利要求1所述的一种基于流程引擎的SQL发布方法,其特征在于,所述判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致,之后还包括:
若当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果不一致,则返回当前执行的SQL文件的错误码;
根据预先为所述错误码配置的是否忽略选项,确定是否继续执行当前执行的SQL文件的下一条SQL文件。


3.根据权利要求2所述的一种基于流程引擎的SQL发布方法,其特征在于,所述根据预先为所述错误码配置的是否忽略选项,确定是否继续执行当前执行的SQL文件的下一条SQL文件,包括:
若预先为所述错误码配置的是否忽略选项为忽略,则忽略所述错误码,继续执行当前执行的SQL文件的下一条SQL文件;
若预先为所述错误码配置的是否忽略选项为不忽略,则不忽略所述错误码,停止执行当前执行的SQL文件的下一条SQL文件。


4.根据权利要求1-3任一所述的一种基于流程引擎的SQL发布方法,其特征在于,所述判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致,之后还包括:
若当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果一致,则继续执行当前执行的SQL文件的下一条SQL文件。


5.根据权利要求1所述的一种基于流程引擎的SQL发布方法,其特征在于,所述判断当前执行的SQL文件的实际执行结果与当前执行的SQL文件的预期执行结果是否一致,之后还包括:
显示当前执行的SQL文件的执行日志,以供用...

【专利技术属性】
技术研发人员:沈世鑫
申请(专利权)人:北京中亦安图科技股份有限公司
类型:发明
国别省市:北京;11

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1