一种基于数据仓库的数据开发方法及系统与流程

文档序号:21031897发布日期:2020-06-09 20:13阅读:274来源:国知局
一种基于数据仓库的数据开发方法及系统与流程

本发明涉及数据仓库领域,特别涉及一种基于数据仓库的数据开发方法及系统。



背景技术:

数据仓库,英文名称为datawarehouse,可简写为dw或dwh。数据仓库,是为企业所有级别的决策制定过程,提供所有类型数据支持的战略集合。它是单个数据存储,出于分析性报告和决策支持目的而创建。

现有技术中实现数据仓库上的数据开发,需要实现的步骤有如下步骤:第一步,购买、部署商业版etl开发平台。第二步,在商业平台上配置数据入库抽取信息。第三步,写数据开发脚本,用商业平台定时调度。第四步,在商业平台上把开发后的数据抽取到常用数据库中。第五步,第三方应用读取常用数据库。

现有的数据库开发平台有以下缺陷:平台功能不一定适合本项目的实际情况,每个项目的数据开发粒度不一样,采用商业版平台只能采用的是满足开发粒度很细的开发流程,才能覆盖面广,这样导致开发粒度没有那么细的项目必须适应平台的复杂流程,用户体验差。产品质量缺陷无法及时解决,产品本身是闭源的,质量缺陷只能靠产品公司进行bug修改,版本升级来解决,无法调动开源社区的群策群力来快速升级,快速解决问题。



技术实现要素:

本发明的目的在于:提供了一种基于数据仓库的数据开发方法及系统,解决了现有的数据库开发平台功能不一定适合本项目的实际情况,每个项目的数据开发粒度不一样,采用商业版平台只能采用的是满足开发粒度很细的开发流程,才能覆盖面广,这样导致开发粒度没有那么细的项目必须适应平台的复杂流程,用户体验差的问题。

本发明采用的技术方案如下:

一种基于数据仓库的数据开发方法,包括以下步骤:

s1、将元数据加载到hive中;

s2、在hive上进行数据开发;

s3、将步骤s2中数据开发的结果表同步到目标数据库中。

本方案通过将元数据加载到hive中,在通过现有的python、sql等技术在hive上进行数据开发,由于python、sql等技术是较为现有的技术,因此,技术人员可以根据项目的实际情况对数据开发的流程进行配置调整,同时所需要使用的组件大部分是开源社区免费支持的,各组件可以较为便捷升级版本,达到更好的性能和功能的提升。解决了现有的数据库开发平台扩展性、适应性较差的问题。

进一步的,所述储存元数据的数据库包括关系型数据库和es数据库中的至少一种。

进一步的,所述储存元数据的数据库为关系型数据库时,通过sqoop组件将元数据从关系型数据库加载到hive中。

进一步的,所述储存元数据的数据库为es数据库时,通过在hive中创建es映射表将元数据从es数据库加载到hive中。

进一步的,所述步骤s2中通过运行python程序、调用sql文件在hive上进行数据开发

进一步的,所述步骤s3中的目标数据库为关系型数据库。

进一步的,所述步骤s3通过sqoop组件程序,将结果表同步到关系型数据库中。

一种基于数据仓库的数据开发系统,包括数据库、数据仓库和操作端,所述操作端包括:

存储器,用于存储可执行指令;

处理器,用于执行所述存储器中存储的可执行指令,实现上述的一种基于数据仓库的数据开发方法。

综上所述,由于采用了上述技术方案,本发明的有益效果是:

1.本发明一种基于数据仓库的数据开发方法及系统,数据开发粒度可控,各项目对数据治理的粒度不一样,可以通过sql文件里的sql组合自己控制开发粒度和口径;

2.本发明一种基于数据仓库的数据开发方法及系统,组件的缺陷可通过多种方式解决,如通过组件版本升级或者在开源社区群策群力咨询得以解决;

3.本发明一种基于数据仓库的数据开发方法及系统,用到的组件全是开源社区免费支持的,对经费不足的项目减轻了负担,降低开发成本;

4.本发明一种基于数据仓库的数据开发方法及系统,各组件免费升级,组件依赖开源社区庞大后援支持,各组件可以跟着社区一起升级版本,达到更好的性能和功能的提升。

附图说明

为了更清楚地说明本发明具体实施方式或现有技术中的技术方案,下面将对具体实施方式或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图,其中:

图1是本发明的数据开发全流程示意图。

具体实施方式

为了使本发明的目的、技术方案和优点更加清楚,下面将结合图1对本发明作进一步地详细描述,所描述的实施例不应视为对本发明的限制,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其它实施例,都属于本发明保护的范围。

除非另有定义,本文所使用的所有的技术和科学术语与属于本发明的技术领域的技术人员通常理解的含义相同。本文中所使用的术语只是为了描述本发明实施例的目的,不是旨在限制本发明。

对本发明实施例进行进一步详细说明之前,对本发明实施例中涉及的名词和术语进行说明,本发明实施例中涉及的名词和术语适用于如下的解释。

入库:指数据文件加载进数据库中的过程。本文特指数据文件加载到hive的过程

hive:hive是基于hadoop的一个数据仓库工具,数据仓库数据的主要存储形式。

同步:两种数据存储载体上的数据转换过程。

数据开发:指根据用户的口径,对不同粒度的数据按指定维度进行汇总、统计。

sqoop:开源组件,主要用于在hadoop(hive)与传统的关系型数据库,如mysql、oracle、postgres等之间进行数据的传递,可以将一个关系型数据库中的数据导进到hadoop的hdfs中,也可以将hdfs的数据导进到关系型数据库中。

es数据库:es(elasticsearch)是一个基于lucene的搜索服务器,它提供了一个分布式多用户能力的全文搜索引擎,基于restfulweb接口,elasticsearch是用java语言开发的,并作为apache许可条款下的开放源码发布,是一种流行的企业级搜索引擎。

实施例1

一种基于数据仓库的数据开发方法,包括以下步骤:

s1、将元数据加载到hive中;

s2、在hive上进行数据开发;

s3、将步骤s2中数据开发的结果表同步到目标数据库中。

本方案通过将元数据加载到hive中,在通过现有的python、sql等技术在hive上进行数据开发,由于python、sql等技术是较为现有的技术,因此,技术人员可以根据项目的实际情况对数据开发的流程进行配置调整,同时所需要使用的组件大部分是开源社区免费支持的,各组件可以较为便捷升级版本,达到更好的性能和功能的提升。解决了现有的数据库开发平台扩展性、适应性较差的问题。

实施例2

本实施例在实施例1的基础上进一步的,所述储存元数据的数据库包括关系型数据库和es数据库中的至少一种。

进一步的,所述储存元数据的数据库为关系型数据库时,通过sqoop组件将元数据从关系型数据库加载到hive中。

进一步的,所述储存元数据的数据库为es数据库时,通过在hive中创建es映射表将元数据从es数据库加载到hive中。

实施例3

本实施例在实施例1的基础上进一步的,所述步骤s2中通过运行python程序、调用sql文件在hive上进行数据开发

实施例4

本实施例在实施例1的基础上进一步的,所述步骤s3中的目标数据库为关系型数据库。

进一步的,所述步骤s3通过sqoop组件程序,将结果表同步到关系型数据库中。

实施例5

一种基于数据仓库的数据开发系统,包括数据库、数据仓库和操作端,所述操作端包括:

存储器,用于存储可执行指令;

处理器,用于执行所述存储器中存储的可执行指令,实现上述的一种基于数据仓库的数据开发方法。

实施例6

如图1所示,一种基于本方案的数据开发实例,首先,etl操作端对数据文件执行字符集转换脚本(encode_help.sh),然后执行入库脚本(file2hive.py)将数据文件导入hive中,然后数据开发操作端通过执行脚本(exechql.py)分别在ods、dw、dws和app中对数据文件进行开发得到结果表,最后数据开发操作端通过执行同步脚本(h2o.py)将结果表同步到关系数据库管理系统rdbms。其中,入库脚本(file2hive.py)和同步脚本(h2o.py)基于sqoop组件程序实现,执行脚本(exechql.py)为用于操作sql文件的python模板程序。采用本方案,可以通过调整sql文件里的sql组合自己控制开发粒度和口径以适应不同的项目需求,同时所需要使用的组件大部分是开源社区免费支持的,各组件可以较为便捷升级版本,达到更好的性能和功能的提升。解决了现有的数据库开发平台扩展性、适应性较差的问题。

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

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

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

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

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

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